国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

深入理解 —— call() 和 apply()

curried / 1187人閱讀

摘要:使用將的改為了對象上面這個例子可以很直觀地理解的工作原理。所以在執(zhí)行時,函數(shù)內(nèi)部的則會自動指向。這是一個非常好理解的例子。當執(zhí)行這個方法時,獲得的屬性和方法。因此執(zhí)行時返回。這證明了我們上面的推理是正確的。

js中一個主要的內(nèi)容就是this的指向問題.

apply()call() 這兩個方法有共同之處也有不同之處

共同之處

他們都能改變this的指向,都是在特定的作用域中調(diào)用函數(shù),等于設置函數(shù)體內(nèi)this對象的值,以擴充函數(shù)賴以運行的作用域。一般來說,this總是指向調(diào)用某個方法的對象,但是使用call()apply()方法時,就會改變this的指向。

說到他們的功能,我就拿call來舉例子吧,因為他們的功能是一致的。

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

call()方法就是用來代替另一個對象來調(diào)用這個方法。call()將一個函數(shù)的對象上下文從初始的變?yōu)樾露x的新對象thisObj。如果沒有這個對象,那么就用global來代替.

不同之處

不同之處在于他們傳值的方式不同

applycall兩者在作用上是相同的,但兩者在參數(shù)上有區(qū)別的。對于第一個參數(shù)意義都一樣,但對第二個參數(shù):apply傳入的是一個參數(shù)數(shù)組,也就是將多個參數(shù)組合成為一個數(shù)組傳入,而call則作為call的參數(shù)傳入(從第二個參數(shù)開始)。如 func.call(func1,var1,var2,var3)對應的 apply 寫法為:func.apply(func1,[var1,var2,var3])

function sayName(){
    alert(this.name);
}

var p = {
    name: "zjj"
};

sayName.call(p); // zjj 
//使用call將sayName的this改為了p對象
上面這個例子可以很直觀地理解 call 的工作原理。也就是說,當在函數(shù)中調(diào)用 call 這個方法時,函數(shù)內(nèi)部的 this 對象會自動指向 call 方法中的第一個參數(shù)。在上面這個例子中也就是 peter 這個對象了。所以在執(zhí)行 sayName.call(peter) 時,函數(shù)內(nèi)部的 this.name 則會自動指向 peter.name 。故最終結果為 peter。這是一個非常好理解的例子。接下來來看較為復雜的情況。

call()

function person(){
    this.name = "zjj";
    this.say = function() {
        console.log(this.name);
    }
}

function person1(){
    this.name = "zmf";
}

var sm = new Person1();

person.call(sm); //將person的this指向改為了sm
sm.say(); // 這里之所以能使用say,是因為現(xiàn)在sm指向了person,有say這個方法;
    window.color = "red";
    document.color = "yellow";

    var s1 = {color: "blue" };
    function changeColor(){
        console.log(this.color);
    }

    changeColor.call();         //red (默認傳遞參數(shù))
    changeColor.call(window);   //red
    changeColor.call(document); //yellow
    changeColor.call(this);     //red
    changeColor.call(s1);       //blue
// 在call中傳入函數(shù)
function class1 () {  
    this.message = "yeah";
}

function class2 () {  
    this.sayMessage = function () {
        alert(this.message);
    }
}

class2.call(class1);   // 可以理解為class2給了class1;
alert(class1.sayMessage);  // 因為即使是將class2的給了class1,但是sayMessage中的this.message仍然還是class2的。
class1.sayMessage(); //undefined
var message = "hi";

function class1 () {  
    this.message = "yeah";
}

function class2 () {  
    this.message = "hello";
    this.sayMessage = function () {
        alert(this.message);
    }
}

class2.call(class1);  
alert(class1.sayMessage);  
class1.sayMessage(); // hello

class1.message = "msg";

class1.sayMessage(); //msg  

第一次調(diào)用 sayMessage 方法,返回 hello 。我們再來看一下 class2.call(class1) 這個過程。當執(zhí)行這個方法時,class1 獲得 class2 的 message 屬性和 sayMessage 方法。所以此時有 class1.message = "hello" ,class1.sayMessage = function () {alert(this.message)}。因此執(zhí)行 sayMessage 時返回 hello。當我們手動修改 class1.message 時,再調(diào)用這個方法,返回的值為我們修改的值。這證明了我們上面的推理是正確的。

apply()

function add(c,d){
        return this.a + this.b + c + d;
    }

    var s = {a:1, b:2};
    console.log(add.call(s,3,4)); // 1+2+3+4 = 10
    console.log(add.apply(s,[5,6])); // 1+2+5+6 = 14 

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/94992.html

相關文章

  • applycall 詳細深入理解

    apply 與 call 介紹 function f1(x, y) { console.log(結果是: + (x + y) + this); } f1(10, 20); //函數(shù)的調(diào)用 // 結果是:30[object Window] // 此時的 f1 實際上是當作對象來使用的,對象可以調(diào)用方法 f1.apply(); // 結果是:NaN[object Window] f1.ca...

    Hegel_Gu 評論0 收藏0
  • 深入淺出JavaScript之call()、apply()方法

    摘要:的作用在中,方法和方法都是為了改變函數(shù)運行時上下文而存在的,換句話說就是為了改變函數(shù)體內(nèi)部的指向。歡迎前端大牛糾正錯誤,如有錯誤我會及時改正。 寫在前面: 隔了很長時間了,也不知道寫點什么。最近一直在研究ES6,一直想寫出來的文章能對初學者或者是在學習JS路上有所幫助的。這就是我的初衷。 call、apply的作用 在JavaScript中,call()方法和apply()方法都是為了...

    Cympros 評論0 收藏0
  • 深入理解JavaScript(三):獲取數(shù)組中的最大值方法(this,apply

    摘要:三個方法的作用,都是改變的指向,只是用法稍微有些區(qū)別什么是既不指向函數(shù)自身,也不指函數(shù)的詞法作用域。它在函數(shù)定義的時候是確定不了的在函數(shù)被調(diào)用時才發(fā)生的綁定,也就是說具體指向什么,取決于你是怎么調(diào)用的函數(shù)。 1.排序法 思路:給數(shù)組先排序(由大到小排序),第一項就是最大值 let arr = [1,5,6,7,9,20,40,2,3]; let max1 = arr.sort(func...

    canopus4u 評論0 收藏0
  • 從Ecma規(guī)范深入理解this

    摘要:本文總結了的各種情況,并從規(guī)范的角度探討了的具體實現(xiàn),希望對大家理解有所幫助。規(guī)范規(guī)范里面詳細介紹了的實現(xiàn)細節(jié),通過閱讀規(guī)范,我們可以更準確的理解上述四種情況到底是怎么回事。由于本人能力有限,如有理解錯誤的地方還望指出。 this是面向?qū)ο缶幊讨械囊粋€概念,它一般指向當前方法調(diào)用所在的對象,這一點在java、c++這類比較嚴格的面向?qū)ο缶幊陶Z言里是非常明確的。但是在javascript...

    rottengeek 評論0 收藏0
  • 深入理解 Javascript 之 this

    摘要:深入淺出的理解問題的由來寫法一寫法二雖然和指向同一個函數(shù),但是執(zhí)行結果可能不一樣。該變量由運行環(huán)境提供。所以,就出現(xiàn)了,它的設計目的就是在函數(shù)體內(nèi)部,指代函數(shù)當前的運行環(huán)境。 深入淺出this的理解 問題的由來 var obj = { foo: function(){} } var foo = obj.foo; // 寫法一 obj.foo(); // 寫法二 foo...

    OnlyMyRailgun 評論0 收藏0

發(fā)表評論

0條評論

curried

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<