2016年5月26日下午(妙味課堂js基礎-1筆記三)

来源:http://www.cnblogs.com/zzjeny/archive/2016/05/26/5531317.html
-Advertisement-
Play Games

本課內容:1. 函數返回值:return,沒有return的函數返回值是什麼?2. 函數傳參、arguments(可變參、不定參)3. arguments應用實例:任意數字求和4. 實例:CSS函數5. 獲取非行間樣式:currentStyle、getComputedStyle(obj, false ...


本課內容:
1. 函數返回值:return,沒有return的函數返回值是什麼?
2. 函數傳參、arguments(可變參、不定參)
3. arguments應用實例:任意數字求和
4. 實例:CSS函數
5. 獲取非行間樣式:currentStyle、getComputedStyle(obj, false)[attr]
6. 封裝可重用的getStyle()函數
7. 函數傳參的可讀性

一、函數返回值

    (1)什麼是函數返回值

      函數的執行結果

<script type="text/javascript">
        function sum(a,b) {
            return a+b;
        }
        alert(sum(12,6));
    </script

      可以沒有return

<script type="text/javascript">
        function show() {
      return; } alert(show());      //返回undefined
</script>

    (2)一個函數應該只返回一種類型的值

  1. 函數返回值:return,沒有return的函數返回值是什麼?

    沒有return或者return後面沒有東西,都會返回undefined。

二、函數傳參

  可變參(不定參):arguments(就是一個數組,存的是所有參數;)

<script type="text/javascript">
        function show() {
            alert(arguments.length);
        }
        show(12,5);
    </script>
//直接彈出2;用來獲取這個函數有多少個參數;

    在函數代碼中,使用特殊對象 arguments,開發者無需明確指出參數名,就能訪問它們。

    參數的個數可變,參數數組

  例子1:求和

    求所有參數的和

    (1)簡單的小例子

<script type="text/javascript">
        function sum(a,b,c) {
            alert(a+b+c);
        }
        sum(12,5,3);
    </script>

  可變參(不定參):

    求數組裡面所有數字的和:

 <script type="text/javascript">
        function sum() {
           var result=0;
            var i=0;
            for (i=0;i<arguments.length;i++){
                result+=arguments[i];
            }
            alert(result);
        }
        sum(12,5,3,6,8,12,3,4,4,5,6);
    </script>

  例子2:CSS函數

    判斷arguments.length

    給參數取名,增強可讀性

<style type="text/css">
        #div1{width: 200px;height: 200px;background: red;}
    </style>
    <script type="text/javascript">
       function css() {
           if(arguments.length==2){     //獲取
               return  arguments[0].style[arguments[1]];
           }
           else  if(arguments.length==3){       //設置
               arguments[0].style[arguments[1]]=arguments[2];
           }
       }
        window.onload=function () {
            var oBtn=document.getElementById("btn1");
            var oDiv=document.getElementById("div1");
             oBtn.onclick=function () {
                 //css(oDiv,"background","green");
                 alert(css(oDiv,"width"));
             }
        }
    </script>
</head>
<body>
    <input id="btn1"  type="button" value="樣式" />
    <div id="div1" ></div>
</body>

如果是上述代碼的話,彈出來沒有結果,原因是style只能用來讀取行間樣式;

<script type="text/javascript">
       function css() {
           if(arguments.length==2){     //獲取
               return  arguments[0].style[arguments[1]];
           }
           else  if(arguments.length==3){       //設置
               arguments[0].style[arguments[1]]=arguments[2];
           }
       }
        window.onload=function () {
            var oBtn=document.getElementById("btn1");
            var oDiv=document.getElementById("div1");
             oBtn.onclick=function () {
                 //css(oDiv,"background","green");
                 alert(css(oDiv,"width"));
             }
        }
    </script>
</head>
<body>
    <input id="btn1"  type="button" value="樣式" />
    <div id="div1" style="width: 200px;height: 200px;background: red;"></div>
</body>

  如果是這樣的話就可以獲取到寬度為彈出200px;

    問題:如何取非行間樣式(不能用來設置)? 

      ——obj.currentStyle[attr]

  <style>
        #div1 {width:100px; height:100px; background:red;}
    </style>
    <script type="text/javascript">
        window.onload=function () {
            var oDiv=document.getElementById('div1');
      //獲取計算後的樣式   //IE alert(oDiv.currentStyle.width); }
</script> </head> <body> <div id="div1"></div> </body>

  相容性:(這裡有問題,彈不出來!)

      ——getComputedStyle(obj, false)[attr]

<script type="text/javascript">
    window.onload=function (){
      var oDiv=document.getElementById('div1');
      //獲取計算後的樣式(當前樣式、最終樣式)
      //IE
      //alert(oDiv.currentStyle.width);
      //FF
      //alert(getComputedStyle(oDiv, false).width);
      if(oDiv.currentStyle){
          //IE
         alert(oDiv.currentStyle.width);    //IE下彈出
      }
      else{
          //FF
          alert(getComputedStyle(oDiv, false).width);  //FF下也可以彈出;
      }
    }
</script>
</head>
<body>
    <div id="div1"></div>
</body>

  下麵我們把這個封裝成為一個簡單的函數:

<script type="text/javascript">
    //哪個元素
    //哪個樣式
        function getStyle(obj, attr) {
            if(obj.currentStyle) {
                return obj.currentStyle[attr];
            }
            else {
                return getComputedStyle(obj, false)[attr];
            }
        }
        window.onload=function () {
            var oDiv=document.getElementById('div1');
            alert(getStyle(oDiv, 'backgroundColor'));  //width(單一樣式),fontSize(複合樣式).......
        }
    </script>
</head>
<body>
    <div id="div1"></div>
</body>

   關於參數和argument:

<script type="text/javascript">
    function show(a, b){
    alert(arguments[0]);
    }
    show(12, 6);
</script>

  最後簡化代碼:

<script type="text/javascript">
        function css(obj,attr,value) {
            if(arguments.length==2){     //獲取
                return getStyle(obj,attr);
            }
            else  if(arguments.length==3){       //設置
                obj.style[attr]=value;
            }
        }
        window.onload=function () {
            var oBtn=document.getElementById("btn1");
            var oDiv=document.getElementById("div1");
            oBtn.onclick=function () {
                css(oDiv,"background","green");
                alert(css(oDiv,"width"));
            }
        }
    </script>
</head>
<body>
<input id="btn1"  type="button" value="樣式" />
<div id="div1" style="width: 200px;height: 200px;background: red;"></div>
</body>

   最後,這裡還有關於底層的獲取元素CSS值之getComputedStyle方法熟悉沒有弄懂,後面有時間可以參考:

    http://www.zhangxinxu.com/wordpress/?p=2378


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 先看顯示效果: 對應HTML代碼: 對應元素習慣樣式: ...
  • 1.正則表達式到底是什麼東西? 在編寫處理字元串的程式或網頁時,經常會有查找符合某些複雜規則的字元串的需要。正則表達式就是用於描述這些規則的工具。換句話說,正則表達式就是記錄文本規則的代碼。 很可能你使用過Windows/Dos下用於文件查找的通配符(wildcard),也就是*和?。如果你想查找某 ...
  • <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> .box{ display:block; height:350px; width:250px; background:#ddd; curso ...
  • 簡潔而神秘的語法: 正則表達式的語法非常簡潔,而且對於不熟悉正則表達式的人,看起來簡直很神秘。有時,正則表達式中看起來好像到處都充斥著反斜杠、圓括弧和方括弧。而只要理解正則表達式中每個字元串和元字元的作用,就能自己編寫正則表達式或者分析其他開發人員編寫的正則表達式。 元字元是指在正則表達式模式中具有... ...
  • 其實實際上實現中並不能讓password中顯示文字提示,但是我們在工作中有這樣的需求,當沒輸入東西的時候,框內有提示輸入密碼,但是當輸入東西的時候又顯示的是*號,那麼是如何實現的呢?其實原理很簡單,就是放兩個文本框,樣式以及定位都是一樣的。先將type為password的隱藏,只顯示type為tex ...
  • 一、什麼是正則表達式。 解析:在編寫處理字元串的程式或網頁時,經常會有查找符合某些複雜規則的字元串的需要。 正則表達式就是用於描述這些規則的工具。 用俗話說,正則表達式就是記錄文本規則的代碼。 二、入門。 我用一個故事與大家說明。 1)老師組織一個活動在電腦文本html.txt中查找帶"hi"開頭的 ...
  • 自我反思 學習 之前做的東西,用到table裡面數據的分頁小標簽都是用的插件,好看又方便,今天腦子抽抽了看了看人家的代碼,大寫的蒙圈,就找了找簡單的,還好俺這個小菜鳥還算能看懂,學者比划了兩下子,以後慢慢做的漂亮些就能用到項目裡面了,哈哈,我驕傲! 第一個:實現的很常見很簡單的顯示頁數翻頁 效果圖: ...
  • LN :跟著W3School學HTML 006 內容參考自W3School [HTML 教程][1] HTML段落 瀏覽器會自動地在段落的前後添加空行。(`` 是塊級元素) 不要忘記結束標簽。 實例解析 This is a paragraph This is another paragraph 效果 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...