第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

Object.prototype.toString.call(this)和Object.prototype.toString(this)的區(qū)別;

function fo(){

? console.log(this); ? ? ?

? console.log(Object.prototype.toString.call(this));

? console.log(Object.prototype.toString(this));

}

fo.call("hello");

運(yùn)行結(jié)果:

String { 0="h", ?1="e", ?2="l", 3="l" ,4="o"}

[object String]

[object Object]

求解釋以上的三種結(jié)果


正在回答

2 回答

fo.call("hello"); ?這樣用call去調(diào)用foo,目的就是修改fo函數(shù)內(nèi)的this。由于使用call/apply時(shí)(一般非嚴(yán)格模式下)會(huì)進(jìn)行基本類(lèi)型到包裝類(lèi)型的轉(zhuǎn)換,所以fo中的this實(shí)際上是new String("hello"); 是一個(gè)String對(duì)象。

function?foo(){
????console.log(typeof?this);?//?"object"
????console.log(this.toString());?//?"hello"
}??
foo.call("hello");

所以第一個(gè)console.log輸出String對(duì)象。

第二個(gè)在第一章數(shù)據(jù)類(lèi)型章節(jié)講過(guò),通過(guò)Object.prototype.toString.apply/call可以間接拿到對(duì)象的內(nèi)部[[class]]標(biāo)簽,對(duì)于String對(duì)象會(huì)返回[object String]


而直接調(diào)用Object.prototype.toString會(huì)返回[object Object],是因?yàn)槿绱苏{(diào)用內(nèi)部this指向的是Object.prototype。

類(lèi)似于:

var?obj?=?{x?:?1};
obj.toString();?//?[object?Object]

需了解Object.prototype是一個(gè)對(duì)象,它作為Object實(shí)例的對(duì)象的原型。

11 回復(fù) 有任何疑惑可以回復(fù)我~
#1

前端功臣獅

Bosn手動(dòng)點(diǎn)贊
2016-06-23 回復(fù) 有任何疑惑可以回復(fù)我~

Object.prototype.toString.call(this) :

a.call(b); 是將a對(duì)象的方法運(yùn)用到b對(duì)象上,fo.call("hello")?是改變當(dāng)前this對(duì)象的的指向,調(diào)用fo.call("hello")傳入的是一個(gè)String,Object.prototype.toString.call(this) ?是將toString方法運(yùn)用于this對(duì)象,而此時(shí)對(duì)象為String,多以輸出[object String]?

Object.prototype.toString(this) :

并沒(méi)有改變this對(duì)象的指向,

每一個(gè)object都有toString()方法 并且是被自動(dòng)調(diào)用的,如果不被重寫(xiě) 將會(huì) returns "[object type]" var o = new Object();

o.toString(); ? ? ? ? ? // returns [object Object]

個(gè)人想法 也有點(diǎn)模糊,希望其他大神給予清晰正確的解釋

3 回復(fù) 有任何疑惑可以回復(fù)我~

舉報(bào)

0/150
提交
取消
JavaScript深入淺出
  • 參與學(xué)習(xí)       281087    人
  • 解答問(wèn)題       1054    個(gè)

由淺入深學(xué)習(xí)JS語(yǔ)言特性,且解析JS常見(jiàn)誤區(qū),從入門(mén)到掌握

進(jìn)入課程

Object.prototype.toString.call(this)和Object.prototype.toString(this)的區(qū)別;

我要回答 關(guān)注問(wèn)題
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)