中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

深入理解Javascript中的this關鍵字
來源:易賢網 閱讀:1368 次 日期:2015-03-31 15:40:50
溫馨提示:易賢網小編為您整理了“深入理解Javascript中的this關鍵字”,方便廣大網友查閱!

這篇文章主要介紹了深入理解Javascript中的this關鍵字,本文講解了方法調用模式、函數調用模式、構造器調用模式、apply調用模式中this的不同之處,需要的朋友可以參考下

自從接觸javascript以來,對this參數的理解一直是模棱兩可。雖有過深入去理解,但卻也總感覺是那種浮于表面,沒有完全理清頭緒。

但對于this參數,確實會讓人產生很多誤解。那么this參數到底是何方神圣?

理解this  

this是一個與執行上下文(execution context,也就是作用域)相關的特殊對象。因此,它可以叫作上下文對象(也就是用來指明執行上下文是在哪個上下 文中被觸發的對象)。

任何對象都可以做為上下文中的this的值。在一些對ECMAScript執行上下文和部分this的描述中的 所產生誤解。this經常被錯誤的描述成是變量對象的一個屬性。 再重復一次:

this是執行上下文的一個屬性,而不是變量對象的一個屬性。 這個特性非常重要,因為與變量相反,this從不會參與到標識符解析過程。換句話說,在代碼中當訪問this的時候,它的值是直接從執行上下文中獲取的,并不需要任何作用域鏈查找。this的值只在進入上下文的時候進行一次確定。

廢話不多,先看一個板栗:

代碼如下:

var test = function(){};

test.prototype = {

foo:"apple",

fun:function(){

this.foo="banana";

}

};

var myTest = new test();

myTest.fun();

console.log(myTest.hasOwnProperty("foo")); //輸出什么

console.log(myTest.hasOwnProperty("fun")); //輸出什么

hasOwnProperty:是用來判斷一個對象是否有你給出名稱的屬性或對象。不過需要注意的是,此方法無法檢查該對象的原型鏈中是否具有該屬性,該屬性必須是對象本身的一個成員。

不知道看官們心里的答案是什么,正確的答案是true,false。

代碼如下:

console.log(myTest.hasOwnProperty("foo"));

console.log(myTest.hasOwnProperty("fun"));

true

false

要弄明白為什么是這樣,就必須要理解上面this所扮演的角色,所指代的對象。在《javascript語言精粹》一書中,指出了在javascript中一共有四種調用模式:

1.方法調用模式

2.函數調用模式

3.構造器調用模式

4.apply調用模式

而在這些模式當中,對于如何初始化關鍵參數this上是存在不同差異的。

方法調用模式

當一個函數被保存為對象的一個屬性時,我們稱它為一個方法。當一個方法被調用時,this被綁定到該對象。注意加粗的這句是重點:

代碼如下:

// 創建myObject。它有一個value屬性和一個increment方法

var myObject = {

value: 0;

increment: function(inc) {

this.value += typeof inc ==='number'?inc:1; // 接受一個可選參數,如果不是數字,則默認為數字1

}

};

myObject.increment();

console.log(myObject.value); // 1

myObject.increment(2); //傳入數字2

console.log(myObject.value); // 3

這里,方法increment可以使用this去訪問myObject對象,所以可以改變value的值。而且,this到對象的綁定發生在調用的時候。

函數調用模式

如果一個函數并非一個對象的屬性時,那么它被當作一個函數來調用,此時,this被綁定到全局對象,書上說這是js語言設計的一個缺陷。倘若設計正確,當內部函數被調用的時,this應該仍然綁定到外部函數的this變量。拋開對語言設計的正確與否討論,要當函數調用模式時this變量依舊綁定到該對象,有如下經典解決方案:

代碼如下:

// 給myObject增加一個double方法

var myObject = {

value: 0;

increment: function(inc) {

this.value += typeof inc ==='number'?inc:1; // 接受一個可選參數,如果不是數字,則默認為數字1

}

};

myObject.increment(2);

myObject.double = function () {

var that=this; //解決方法

var helper= function () {

that.value=add(that.value,that.value);

};

helper();

};

myObject.double(); //以方法的形式調用double

console.log(myObject.getValue()); //6

即是給該方法定義一個變量并且把它賦值為this,那么內部函數就可以通過那個變量訪問到this,按照約定,給那個變量命名為that。

構造器調用模式

構造器調用模式即是我一開頭給出的例子所提到的。如果在一個函數前面帶上new來調用,那么將創建一個連接到該函數的prototype成員新對象,同時this將會被綁定到那個新對象上。聽上去十分拗口且難以理解,先再看個demo:

復制代碼 代碼如下:

//構造一個名為Quo的構造器函數,帶有一個status屬性的對象

var Quo = function(string){

this.status =string;

};

Quo.prototype.get_status = function(){

return this.status;

}

var myQuo =new Quo("confuse"); //構造一個Quo實例

console.log(myQuo.get_status()); //confuse

簡單來說,Quo對象下的this在被用為構造一個新實例即new時,this指代的是新生成的myQuo對象而不是Quo對象本身。

一句話,重點就是:原型中的this不是指的原型對象,而是調用對象。

再回過頭看一開始的demo,就很好理解了,在執行myTest.fun()時,this指代了myTest對象,所以生成了一個foo屬性值為“banana”,所以myTest.hasOwnProperty("foo")返回值為true。

Apply調用模式

因為javascript是一門函數式面向對象編程語言,所以函數可以擁有方法。apply方法讓我們構建一個參數數組并用其去調用其他函數,apply方法接收兩個參數,第一個是將被綁定的this的值,第二個是參數數組。說簡單直接一點就是apply方法能劫持另外一個對象的方法,繼承另外一個對象的屬性. 推薦可以看js中apply方法的使用詳細解析 ,就不擺demo了。

學識尚淺,若文中有不正確,請務必指出,誤人子弟實乃大過。

更多信息請查看IT技術專欄

更多信息請查看數據庫
易賢網手機網站地址:深入理解Javascript中的this關鍵字
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
嫩草成人www欧美| 国产九九精品视频| 国产精品捆绑调教| 亚洲欧美另类久久久精品2019| 亚洲永久在线观看| 国内精品久久久久国产盗摄免费观看完整版 | 国产日韩欧美在线视频观看| 亚洲伊人伊色伊影伊综合网| 国产乱人伦精品一区二区| 久久国产精品黑丝| 9i看片成人免费高清| 欧美日韩国内| 久久av红桃一区二区小说| 亚洲国产成人久久综合| 久久动漫亚洲| 99热在线精品观看| 激情六月婷婷久久| 欧美午夜免费电影| 一本在线高清不卡dvd| 国产精品人人做人人爽人人添| 国产一区成人| 欧美日韩在线播放| 性做久久久久久| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲永久免费视频| 国产精品亚洲欧美| 久久久久国色av免费观看性色| 亚洲成人直播| 国产乱码精品一区二区三区忘忧草 | **网站欧美大片在线观看| 欧美日韩成人在线播放| 亚洲国产视频一区| 国产精品久久网站| 欧美成人一区二区三区在线观看 | 欧美精品一区二区三区高清aⅴ| 一本色道久久加勒比精品| 乱中年女人伦av一区二区| 亚洲综合久久久久| 亚洲欧洲美洲综合色网| 国产一区二区三区黄| 国产精品久久久久久av福利软件| 老司机67194精品线观看| 欧美一区二视频| 午夜精品一区二区三区在线视 | 久久久一区二区| 午夜亚洲影视| 久久xxxx精品视频| 久久aⅴ国产紧身牛仔裤| 欧美亚洲一区在线| 久久国产黑丝| 久久亚洲精品中文字幕冲田杏梨| 亚洲欧美日韩国产中文| 亚洲欧美日韩国产综合| 亚洲精品国产精品乱码不99按摩 | 亚洲在线不卡| 欧美激情国产日韩| 欧美经典一区二区三区| 欧美高清视频一区二区三区在线观看| 免费不卡在线视频| 欧美国产先锋| 欧美一区二区三区久久精品茉莉花| 亚洲欧美日韩国产一区| 久久精品国产99国产精品| 免费视频一区| 国产美女精品一区二区三区| 国产亚洲人成a一在线v站| 黄色资源网久久资源365| 亚洲国产精品视频| 日韩视频在线观看一区二区| 午夜精品理论片| 欧美日本在线视频| 国产乱码精品一区二区三区不卡| 狠狠色伊人亚洲综合网站色| 一级日韩一区在线观看| 日韩一级黄色大片| 免费欧美网站| 黄色日韩在线| 欧美一区二区播放| 国产精品亚洲不卡a| 国产在线精品一区二区中文| 亚洲精品乱码久久久久久按摩观| 午夜精品一区二区三区在线视 | 欧美日韩国产成人精品| 国产一区二区三区高清播放| 亚洲深夜福利网站| 欧美日韩天堂| 亚洲图片欧美一区| 国产精品福利网| 亚洲一区二区三| 欧美大片第1页| 一区二区在线免费观看| 中文欧美在线视频| 国产精品永久入口久久久| 欧美一区二区三区在线播放| 国产私拍一区| 亚洲国产一区二区视频| 亚洲色诱最新| 国产综合网站| 欧美伦理一区二区| 欧美一区二区精品久久911| 国产主播一区二区三区| 欧美日韩一区免费| 老牛影视一区二区三区| 久久一区免费| 免费欧美在线视频| 欧美电影美腿模特1979在线看| 免费观看成人鲁鲁鲁鲁鲁视频| 牛牛国产精品| 麻豆精品网站| 亚洲午夜伦理| 久久久综合香蕉尹人综合网| 日韩一区二区精品在线观看| 亚洲精品日本| 欧美一区视频在线| 最近看过的日韩成人| 欧美性大战xxxxx久久久| 欧美亚洲综合网| 在线视频欧美精品| 欧美电影免费观看网站| 亚洲人www| 在线精品视频在线观看高清| 永久免费精品影视网站| 影音先锋另类| 99精品免费视频| 亚洲精品影视在线观看| 国产精品亚洲综合| 免费欧美在线| 欧美国产高潮xxxx1819| 欧美日韩国产一区二区| 国产精品亚洲激情| 亚洲精品1234| 久久国产免费| 国产精品日韩在线观看| 亚洲国产精品传媒在线观看| 亚洲深夜福利视频| 欧美成年人视频网站| 国产欧美短视频| 亚洲图片欧洲图片日韩av| 久久久五月婷婷| 国产亚洲成av人在线观看导航| 亚洲精品精选| 免费成人在线观看视频| 国外成人免费视频| 欧美一级二级三级蜜桃| 国产精品―色哟哟| 亚洲男女毛片无遮挡| 国产精品xxx在线观看www| 久久久久www| 国产一区二区高清视频| 欧美一级理论性理论a| 欧美性大战久久久久| av成人免费观看| 国产精品视频网址| 亚洲制服丝袜在线| 国产欧美日韩一区| 性色av香蕉一区二区| 国产一区二区精品| 欧美一区二区三区视频在线观看| 欧美日韩一区二区三| av成人激情| 国产人成一区二区三区影院| 性亚洲最疯狂xxxx高清| 韩国成人福利片在线播放| 美日韩精品视频免费看| 一本色道久久88综合日韩精品| 国产精品久久久99| 美女脱光内衣内裤视频久久网站| 精品av久久久久电影| 亚洲专区一区二区三区| 欧美日韩精品| 久久国产视频网| 亚洲一级一区| 狠久久av成人天堂| 欧美激情第一页xxx| 亚洲视频一区在线观看| 亚洲国产清纯| 国产片一区二区| 欧美日韩国产精品一卡| 卡通动漫国产精品| 欧美一区二区大片| 中文一区二区| 一区二区三区高清| 亚洲国产精品毛片| 亚洲大胆在线| 亚洲黄色性网站| 在线观看一区视频| 国产一区二区日韩精品| 国产精品自拍在线| 国产精品日韩一区二区| 国产精品久久久久久影视| 欧美日一区二区在线观看 | 亚洲精品欧美日韩专区| 国产伦精品一区二区三区视频孕妇 | 欧美一区二区网站| 久久国产精品免费一区| 久久免费视频一区| 蜜臀99久久精品久久久久久软件| 久久久噜噜噜久久人人看| 欧美xart系列在线观看| 欧美日韩国产精品自在自线|