2019-05-14 this&arguments

this 是隱藏的第一個(gè)參數(shù),且一般是對(duì)象
function f(){
console.log(this)
console.log(arguments)
}
f.call() // window []
f.call({name:'frank'}) // {name: 'frank'}, [] 第一項(xiàng)是this,后面的是arguments
f.call({name:'frank'},1) // {name: 'frank'}, [1]
f.call({name:'frank'},1,2) // {name: 'frank'}, [1,2]
arguments是個(gè)偽數(shù)組


image.png

this 為什么必須是對(duì)象
因?yàn)?this 就是函數(shù)與對(duì)象之間的羈絆


image.png

假如這里傳的是個(gè)數(shù)字10,也會(huì)被new Number(10)下,變成數(shù)字對(duì)象


image.png

image.png

// 新手疑惑的兩種寫法
var fn = person.sayHi

person.sayHi() // this === person
fn() // this === window

fn.call(asThis, p1,p2) 是函數(shù)的正常調(diào)用方式
當(dāng)你不確定參數(shù)的個(gè)數(shù)時(shí),就使用 apply
fn.apply(asThis, params)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • this 是隱藏的第一個(gè)參數(shù),且一般是對(duì)象(如果不是對(duì)象,就顯得很沒有意義了) function f(){ ...
    _William_Zhang閱讀 173評(píng)論 0 0
  • 單例模式 適用場景:可能會(huì)在場景中使用到對(duì)象,但只有一個(gè)實(shí)例,加載時(shí)并不主動(dòng)創(chuàng)建,需要時(shí)才創(chuàng)建 最常見的單例模式,...
    Obeing閱讀 2,093評(píng)論 1 10
  • JavaScript(面向?qū)ο?原型理解+繼承+作用域鏈和閉包+this使用總結(jié)) 一、面向?qū)ο?1、什么是面向?qū)?..
    老頭子_d0ec閱讀 304評(píng)論 0 0
  • 一、Node快速體驗(yàn) 1、 Node介紹 (1) Node.js是什么 Node 是一個(gè)基于Chrome V8 ...
    寵辱不驚丶?xì)q月靜好閱讀 3,346評(píng)論 0 6
  • var a = 1; console.log(typeof a);// 'number' var b = '1';...
    zdnexus閱讀 336評(píng)論 0 0