你必須知道的Javascript知識(shí)點(diǎn)之"this指針"的應(yīng)用
很多人都知道this指針,這篇文章的主要目的是為了培訓(xùn)我們公司的新人。
默認(rèn)的this指針指向
規(guī)則1
this指針默認(rèn)指向方法調(diào)用時(shí)為其指定的對(duì)象,如:obj.fun(),fun方法體中的this指針指向obj。
var user = { name: '段光偉' };
user.getName = function(){ return this.name; };
user.getName(); //返回‘段光偉'
var user = { name: '段光偉' };
user.getName = function(){ return this.name; };
user.getName(); //返回‘段光偉'
window.name = '李妞妞';
window.getName = user.getName
window.getName(); //返回‘李妞妞'
getName(); //返回‘李妞妞'
規(guī)則2
如果在方法調(diào)用時(shí)沒(méi)有為方法指定對(duì)象則this指針默認(rèn)指向window,如:fun(),fun方法體中的this指針指向window。
var fun = function(){
return this;
}
fun(); //返回window對(duì)象
規(guī)則3沒(méi)有在方法體中的代碼可以看作執(zhí)行在一個(gè)匿名方法,根據(jù)規(guī)則2可以推論出其this指針指向window。
this //window對(duì)象
改變this指針的默認(rèn)指向
使用apply
var user = { name: '段光偉' };
user.hi= function(message){ return this.name+':'+message; };
window.name = '李妞妞'
user.hi('你好'); //輸出‘段光偉:你好'
user.hi.apply(window, ['你好']); //輸出‘李妞妞:你好'
使用call
var user = { name: '段光偉' };
user.hi= function(message){ return this.name+':'+message; };
window.name = '李妞妞'
user.hi('你好'); //輸出‘段光偉:你好'
user.hi.call(window, '你好'); //輸出‘李妞妞:你好'
構(gòu)造函數(shù)中的this指向
構(gòu)造函數(shù)中的this指針默認(rèn)指向執(zhí)行正在構(gòu)造的對(duì)象。
var User = function(name){
this.name = name;
};
User.prototype.hi = function(){
return this.name;
};
var user = new User('段光偉');
user.hi(); //輸出‘段光偉'
最后的小測(cè)試
猜猜最后的輸出時(shí)什么?
var User = function(name){
this.name = name;
};
User.prototype.hi = function(){
return this.name;
};
var user = new User('段光偉');
user.hi(); //輸出‘段光偉'
var hi = user.hi;
hi(); //猜猜這里的輸出
相關(guān)文章
原生js實(shí)現(xiàn)shift/ctrl/alt按鍵的獲取
小測(cè)試shift、ctrl、alt按鍵的獲取,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04
js編寫(xiě)當(dāng)天簡(jiǎn)單日歷效果【實(shí)現(xiàn)代碼】
下面小編就為大家?guī)?lái)一篇js編寫(xiě)當(dāng)天簡(jiǎn)單日歷效果【實(shí)現(xiàn)代碼】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05
一文教你用javascript實(shí)現(xiàn)條形碼和二維碼
這篇文章主要為大家介紹了如何用javascript實(shí)現(xiàn)條形碼和二維碼示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
一文教會(huì)你從零開(kāi)始畫(huà)echarts地圖
ECharts是一個(gè)使用JavaScript實(shí)現(xiàn)的開(kāi)源可視化庫(kù),涵蓋各行業(yè)圖表,滿足各種需求,下面這篇文章主要給大家介紹了如何從零開(kāi)始畫(huà)echarts地圖的相關(guān)資料,需要的朋友可以參考下2022-04-04
js實(shí)現(xiàn)文字超出部分用省略號(hào)代替實(shí)例代碼
關(guān)于超出一定字?jǐn)?shù)用省略號(hào)顯示的問(wèn)題,這種要求在我們?nèi)粘i_(kāi)發(fā)的時(shí)候經(jīng)常見(jiàn)到,我們之前基本都是用CSS來(lái)完成的,今天給大家分享個(gè)Javascript實(shí)現(xiàn)這個(gè)功能的示例代碼,有需要的可以參考借鑒。2016-09-09
JavaScript必知必會(huì)(十) call apply bind的用法說(shuō)明
這篇文章主要介紹了JavaScript必知必會(huì)(十) call apply bind的用法說(shuō)明 的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06

