var me = { name : 'Jimbor', blog : 'http://jmedia.cn/', sayMyName : function(){ var pre = 'My name is: '; function displayName(){ alert(pre + this.name); } displayName(); } } me.sayMyName();
從代碼上看,我們希望通過sayMyName()的調用來顯示me的name屬性,即:My name is: Jimbor。但瀏覽器的執行結果是:
var me = { name : 'Jimbor', blog : 'http://jmedia.cn/', sayMyName : function(){ var pre = 'My name is: '; function displayName(){ alert(pre + this.name); } displayName.apply(me); } } me.sayMyName();
再看瀏覽器執行結果: My name is: Jimbor 類似的函數還有call()。區別是call()傳參的方式是一個接一個而不是打包成一個數組。 方法二:用that替換this 即我們可以在最外層的函數定義一個變量來指向this所指向的對象,一旦內部的函數需要調用this時,我們就用這個定義的變量。通常根據習慣,會將這個變量命名為that。那么原來的代碼可以改成這樣:
var me = { name : 'Jimbor', blog : 'http://jmedia.cn/', sayMyName : function(){ var pre = 'My name is: '; var that = this; function displayName(){ alert(pre + that.name); } displayName(); } } me.sayMyName();