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é)果
2015-03-28
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ì)象的原型。
2015-03-27
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)模糊,希望其他大神給予清晰正確的解釋