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

為了賬號安全,請及時綁定郵箱和手機立即綁定

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");

運行結果:

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

[object String]

[object Object]

求解釋以上的三種結果


正在回答

2 回答

fo.call("hello"); ?這樣用call去調用foo,目的就是修改fo函數內的this。由于使用call/apply時(一般非嚴格模式下)會進行基本類型到包裝類型的轉換,所以fo中的this實際上是new String("hello"); 是一個String對象。

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

所以第一個console.log輸出String對象。

第二個在第一章數據類型章節(jié)講過,通過Object.prototype.toString.apply/call可以間接拿到對象的內部[[class]]標簽,對于String對象會返回[object String]


而直接調用Object.prototype.toString會返回[object Object],是因為如此調用內部this指向的是Object.prototype。

類似于:

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

需了解Object.prototype是一個對象,它作為Object實例的對象的原型。

11 回復 有任何疑惑可以回復我~
#1

前端功臣獅

Bosn手動點贊
2016-06-23 回復 有任何疑惑可以回復我~

Object.prototype.toString.call(this) :

a.call(b); 是將a對象的方法運用到b對象上,fo.call("hello")?是改變當前this對象的的指向,調用fo.call("hello")傳入的是一個String,Object.prototype.toString.call(this) ?是將toString方法運用于this對象,而此時對象為String,多以輸出[object String]?

Object.prototype.toString(this) :

并沒有改變this對象的指向,

每一個object都有toString()方法 并且是被自動調用的,如果不被重寫 將會 returns "[object type]" var o = new Object();

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

個人想法 也有點模糊,希望其他大神給予清晰正確的解釋

3 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
JavaScript深入淺出
  • 參與學習       281098    人
  • 解答問題       1047    個

由淺入深學習JS語言特性,且解析JS常見誤區(qū),從入門到掌握

進入課程

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

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號