this

1.apply、call 有什么作用,什么區(qū)別

函數(shù)調(diào)用有三種形式:
func(p1,p2)
obj.childrend.method(p1,p2)
func.call(context,p1,p2)
第三種形式才是正常調(diào)用形式,call就是調(diào)用函數(shù)的一種形式,call的第一個(gè)參數(shù)(context)很重要,context就是函數(shù)執(zhí)行的上下文環(huán)境,也就是this。call一個(gè)函數(shù)時(shí)傳入的context是什么,函數(shù)的this就指向什么。如果傳入的context是null或者undefined,那么context默認(rèn)就是window(嚴(yán)格模式下默認(rèn) context 是 undefined)
apply也是調(diào)用函數(shù)的一種形式,和call不同之處在于apply調(diào)用是只能傳入兩個(gè)參數(shù).apply(context,參數(shù)數(shù)組),.call(context,p1,p2)可傳入多個(gè)參數(shù)。


2.下面代碼輸出什么,為什么
func() 

function func() { 
  alert(this)
}

func()等價(jià)于func.call()
輸出的內(nèi)容是window全局對(duì)象


3.以下代碼輸出什么?
var john = { 
  firstName: "John" 
}
function func() { 
  alert(this.firstName + ": hi!")
}
john.sayHi = func
john.sayHi() 

john.sayHi()可寫成john.sayHi.call(john),這里call傳入的context是john這個(gè)對(duì)象,所以this.firstNme的值是'John',打印結(jié)果是John :hi


4.下面代碼輸出什么
function fn0(){
    function fn(){
        console.log(this);
    }
    fn();
}

fn0();

document.addEventListener('click', function(e){
    console.log(this);
    setTimeout(function(){
        console.log(this);
    }, 200);
}, false);

fn0()執(zhí)行后打印的this是全局對(duì)象window,因?yàn)閒n0()執(zhí)行的時(shí)候是window在調(diào)用。
事件綁定后第一次打印的this是觸發(fā)該事件的dom對(duì)象,第二次打印的this是window全局對(duì)象,因?yàn)閟etTimeout和setInterval執(zhí)行時(shí)也是window全局對(duì)象在調(diào)用。


5.下面代碼輸出什么,為什么
var john = { 
  firstName: "John" 
}

function func() { 
  alert( this.firstName )
}
func.call(john) 

.call(context)這里context代表傳入的函數(shù)執(zhí)行的上下文環(huán)境,這里傳入的是john對(duì)象,所以func.call(john)打印的內(nèi)容是John


6.代碼輸出?
var john = { 
  firstName: "John",
  surname: "Smith"
}

function func(a, b) { 
  alert( this[a] + ' ' + this[b] )
}
func.call(john, 'firstName', 'surname') 

func.call(context,參數(shù)1,參數(shù)2) 這里函數(shù)執(zhí)行時(shí)傳入的this是john對(duì)象,所以打印的內(nèi)容是John Smith


7.以下代碼有什么問(wèn)題,如何修改
var module= {
  bind: function(){
    $btn.on('click', function(){
      console.log(this) //this指什么
      this.showMsg();
    })
  },
  
  showMsg: function(){
    console.log('饑人谷');
  }
}

console.log(this)打印的內(nèi)容是觸發(fā)綁定事件的DOM對(duì)象,這里是$btn觸發(fā)所以this指向$btn。代碼中執(zhí)行this.showMsg()會(huì)報(bào)錯(cuò),因?yàn)閠his指向$btn后,$btn上沒(méi)有.showMsg()這個(gè)方法,.showMsg()方法在module對(duì)象上。修改代碼如下

var module= {
  bind: function(){
  var cur=this//申明cur,將this賦值給cur,這里this指向module對(duì)象
    $btn.on('click', function(){
      console.log(this) //綁定事件后this在這里指向$btn
      cur.showMsg();//cur指向module對(duì)象
    })
  },

  showMsg: function(){
    console.log('饑人谷');
  }
}

8.下面代碼輸出什么
var length = 3;
function fa() {
  console.log(this.length);
}
var obj = {
  length: 2,
  doSome: function (fn) {
    fn();
    arguments[0]();
  }
}
obj.doSome(fa)

obj.doSome(fa)等價(jià)于
obj.doSome.call(obj,fa),注意雖然這里this指向obj,但參數(shù)2位置上是fa函數(shù),doSome定義傳入?yún)?shù)并執(zhí)行'fn()',所以參數(shù)2位置上的fa()要執(zhí)行,fa()等價(jià)于fa.call(null),因?yàn)閚ull所以this指向全局對(duì)象window,因?yàn)閘ength=3實(shí)在全局對(duì)象下聲明的,所以第一次打印結(jié)果為3.
執(zhí)行arguments[0]()時(shí),等價(jià)于arguments[0].call(arguments)由于arguments是類數(shù)組對(duì)象,相當(dāng)于傳入的第0個(gè)參數(shù)執(zhí)行,這里傳入的第0個(gè)參數(shù)是fa,所以等價(jià)于fa.call(arguments),這時(shí)候this指向arguments類數(shù)組對(duì)象,arguments.length=1,因?yàn)橹挥?個(gè)參數(shù)fa(),所以第二次打印1


9.下面代碼輸出什么? why
obj = {
  go: function() { alert(this) }
}
obj.go(); 
(obj.go)(); 
(a = obj.go)(); 
(0 || obj.go)(); 

1.obj.go()等價(jià)于obj.go.call(obj) this指向obj,所以打印obj對(duì)象
2.(obj.go)()相當(dāng)于obj對(duì)象上的go屬性立即執(zhí)行,go是個(gè)函數(shù)所以等價(jià)于obj.go.call(obj)打印obj對(duì)象
3.obj.go賦值給全局對(duì)象a,等價(jià)于a=function(){alert(this)},a()---->a.call(),這里打印的是window全局對(duì)象
4.注意這里執(zhí)行或運(yùn)算函數(shù)時(shí),是全局對(duì)象window在調(diào)用,因?yàn)榈谝粋€(gè)0不成立所以等價(jià)于obj.go.call()。所以打印window全局對(duì)象

****本文版權(quán)歸本人和饑人谷所有,轉(zhuǎn)載請(qǐng)注明來(lái)源。****

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 簡(jiǎn)答題 1.apply、call 有什么作用,什么區(qū)別 call apply,調(diào)用一個(gè)函數(shù),傳入函數(shù)執(zhí)行上下文及參...
    GarenWang閱讀 580評(píng)論 1 4
  • 問(wèn)答 apply、call 有什么作用,什么區(qū)別? 在介紹apply和call之前,我們先來(lái)看看this,this...
    小木子2016閱讀 309評(píng)論 0 0
  • javascript里的this指針邏輯上的概念也是實(shí)例化對(duì)象,這一點(diǎn)和java語(yǔ)言里的this指針是一致的,但是...
    天外來(lái)人閱讀 529評(píng)論 0 0
  • 與其他語(yǔ)言相比,函數(shù)的this關(guān)鍵字在JavaScript中的表現(xiàn)略有不同,此外,在嚴(yán)格模式和非嚴(yán)格模式之間也會(huì)有...
    codingC閱讀 637評(píng)論 0 0
  • 昨天一直在趕非文學(xué)翻譯的presentation ppt,差不多十二點(diǎn)才睡覺(jué),躺在床上時(shí)又過(guò)了一下要點(diǎn)評(píng)的內(nèi)容,輾...
    敏哥兒閱讀 802評(píng)論 0 1

友情鏈接更多精彩內(nèi)容