<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    thinking

    one platform thousands thinking

    關于JavaScript中apply與call的用法意義及區別(轉)

    關于JavaScript中apply與call的用法意義及區別(轉)

    JavaScript中有一個call和apply方法,其作用基本相同,但也有略微的區別。

    先來看看JS手冊中對call的解釋:

    call 方法
    調用一個對象的一個方法,以另一個對象替換當前對象。

    call([thisObj[,arg1[, arg2[,   [,.argN]]]]])

    參數
    thisObj
    可選項。將被用作當前對象的對象。

    arg1, arg2,  , argN
    可選項。將被傳遞方法參數序列。

    說明
    call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的對象上下文從初始的上下文改變為由 thisObj 指定的新對象。

    如果沒有提供 thisObj 參數,那么 Global 對象被用作 thisObj。

    說明白一點其實就是更改對象的內部指針,即改變對象的this指向的內容。這在面向對象的js編程過程中有時是很有用的。

    引用網上一個代碼段,運行后自然就明白其道理。

    <input type="text" id="myText"   value="input text">
    <script>
        
    function Obj(){this.value="對象!";}
        
    var value="global 變量";
        
    function Fun1(){alert(this.value);}

        window.Fun1();   
    //global 變量
        Fun1.call(window);  //global 變量
        Fun1.call(document.getElementById('myText'));  //input text
        Fun1.call(new Obj());   //對象!
    </script>

    call函數和apply方法的第一個參數都是要傳入給當前對象的對象,及函數內部的this。后面的參數都是傳遞給當前對象的參數。
    運行如下代碼:
    <script>
       
    var func=new function(){this.a="func"}
        
    var myfunc=function(x){
            
    var a="myfunc";
            alert(
    this.a);
            alert(x);
        }
        myfunc.call(func,
    "var");
    </script>

    可見分別彈出了func和var。到這里就對call的每個參數的意義有所了解了。

    對于apply和call兩者在作用上是相同的,但兩者在參數上有區別的。
    對于第一個參數意義都一樣,但對第二個參數:
    apply傳入的是一個參數數組,也就是將多個參數組合成為一個數組傳入,而call則作為call的參數傳入(從第二個參數開始)。

    如 func.call(func1,var1,var2,var3)對應的apply寫法為:func.apply(func1,[var1,var2,var3])

    同時使用apply的好處是可以直接將當前函數的arguments對象作為apply的第二個參數傳入

    posted on 2011-04-11 10:27 lau 閱讀(360) 評論(0)  編輯  收藏 所屬分類: Web

    主站蜘蛛池模板: 欧美a级在线现免费观看| 最近国语视频在线观看免费播放| 久久综合九色综合97免费下载| 亚洲色偷偷综合亚洲AV伊人| 羞羞的视频在线免费观看| 国产真人无遮挡作爱免费视频 | 亚洲日本一区二区一本一道| 爱情岛亚洲论坛在线观看 | 亚洲 自拍 另类小说综合图区| 亚洲精品自偷自拍无码| 午夜两性色视频免费网站| 亚洲精品无码久久久久A片苍井空| 免费精品一区二区三区在线观看| 亚洲爆乳成av人在线视菜奈实| 日本无卡码免费一区二区三区| 亚洲aⅴ无码专区在线观看春色| 日韩视频在线免费观看| 美女隐私免费视频看| 亚洲精品第一国产综合精品99| a在线视频免费观看在线视频三区| 亚洲乱码中文字幕综合 | fc2免费人成在线视频| 国产亚洲一区二区在线观看| 国产激情免费视频在线观看| 亚洲熟妇av一区| 国产精品色午夜视频免费看| 黄床大片30分钟免费看| 亚洲人成人无码网www电影首页| 8x网站免费入口在线观看| 在线综合亚洲中文精品| 国产成人精品高清免费| baoyu122.永久免费视频| 亚洲美女视频网站| 精品久久免费视频| 中文字幕在线免费观看视频| 亚洲精品视频免费看| 国产在线观看免费视频播放器 | 4hu四虎最新免费地址| 日韩色日韩视频亚洲网站| 亚洲人成在线精品| 亚洲日韩精品A∨片无码|