亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript調用模式與this關鍵字綁定的關系

2019-11-19 13:59:07
字體:
來源:轉載
供稿:網友

Invocation 調用

調用一個函數將暫停當前函數的執行,傳遞控制權和參數給新函數。

實參與形參不一致不會導致運行時錯誤,多的被忽略,少的補為undefined

每個方法都會收到兩個附加參數:this和arguments。this的值取決于調用的模式,調用模式:方法,函數,構造器和apply調用模式
this被賦值發生在被調用的時刻。不同的調用模式可以用call方法實現

var myObject = { value: 0, increment: function (inc) { this.value += typeof inc === 'number' ? inc : 1; } }; myObject.double = function(){ var helper = function(){ console.log(this);// this point to window } console.log(this);// this point to object myObject helper(); } myObject.double();//myObject Window 

1 The Method Invocation Pattern 方法調用模式

方法:函數被保存為對象的屬性.當方法被調用時,this被綁定到該對象

公共方法:通過this取得他們所屬對象的上下文的方法

myObject.increment(); document.writeln(myObject.value); // 

底層實現: myObject.increment。call(myObject,0);

2 The Function Invocation Pattern 函數調用模式

當函數并非對象的屬性時就被當作函數調用(有點廢話。。),this被綁定到全局對象(window)

ECMAScript5中新增strict mode, 在這種模式中,為了盡早的暴露出問題,方便調試。this被綁定為undefined

var add = function (a,b) { return a + b;}; var sum = add(3,4);// sum的值為7 

底層實現:add.call(window,3,4)

strict mode:add.call(undefined,3,4) 

方法調用模式和函數調用模式的區別

function hello(thing) { console.log(this + " says hello " + thing); } person = { name: "Brendan Eich" } person.hello = hello; person.hello("world") // [object Object] says hello world 等價于 person。hello。call(person,“world”) hello("world") // "[object DOMWindow]world" 等價于 hello。call(window,“world”)

3 The Constructor Invocation Pattern

JavaScript是基于原型繼承的語言,同時提供了一套基于類的語言的對象構建語法。

this指向new返回的對象

var Quo = function (string) { this.status = string; }; Quo.prototype.get_status = function ( ) { return this.status; }; var myQuo = new Quo("this is new quo"); //new容易漏寫,有更優替換 myQuo.get_status( );// this is new quo

4 The Apply Invocation Pattern

apply和call是javascript的內置參數,都是立刻將this綁定到函數,前者參數是數組,后者要一個個的傳遞apply也是由call底層實現的

apply(this,arguments[]); call(this,arg1,arg2...); var person = { name: "James Smith", hello: function(thing,thing2) { console.log(this.name + " says hello " + thing + thing2); } } person.hello.call({ name: "Jim Smith" },"world","!"); // output: "Jim Smith says hello world!" var args = ["world","!"]; person.hello.apply({ name: "Jim Smith" },args); // output: "Jim Smith says hello world!" 

相對的,bind函數將綁定this到函數和調用函數分離開來,使得函數可以在一個特定的上下文中調用,尤其是事件bind的apply實現

Function.prototype.bind = function(ctx){ var fn = this; //fn是綁定的function return function(){ fn.apply(ctx, arguments); }; }; bind用于事件中 function MyObject(element) { this.elm = element; element.addEventListener('click', this.onClick.bind(this), false); }; //this對象指向的是MyObject的實例 MyObject.prototype.onClick = function(e) { var t=this; //do something with [t]... };

總結

以上所述是小編給大家介紹的JavaScript調用模式與this關鍵字綁定的關系 ,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
69av在线视频| 欧美大胆a视频| 国产91ⅴ在线精品免费观看| 国产精品国产三级国产专播精品人| 91精品在线国产| 久久久久久网站| 97精品伊人久久久大香线蕉| 国产精品视频男人的天堂| 亚洲成人精品在线| 中文字幕日韩av综合精品| 亚洲精品日韩激情在线电影| 亚洲色图50p| 久热精品视频在线观看| 国产亚洲欧美另类中文| 欧美美最猛性xxxxxx| 国产精品com| 成人在线视频福利| 中文字幕精品一区二区精品| 国产亚洲精品久久久久久777| 亚洲v日韩v综合v精品v| 国产亚洲xxx| 日韩电影视频免费| 疯狂做受xxxx高潮欧美日本| 久久精品中文字幕| 久久久精品国产| 国产成人精品视| 免费99精品国产自在在线| 国产欧美精品va在线观看| 91在线视频导航| 91精品免费看| 精品久久国产精品| 国产免费一区二区三区在线能观看| 青青a在线精品免费观看| 国产精品精品久久久久久| 欧美理论电影网| 欧美精品久久久久| 亚洲国产成人精品一区二区| 精品亚洲永久免费精品| 欧美激情视频在线免费观看 欧美视频免费一| 色哟哟网站入口亚洲精品| 色诱女教师一区二区三区| 久久激情视频免费观看| 久久黄色av网站| 精品网站999www| 国产精品一区二区三区在线播放| 日韩精品在线看| 国产综合福利在线| 不卡毛片在线看| 亚洲自拍偷拍色片视频| 亚洲理论片在线观看| 亚洲精品电影网在线观看| 欧美男插女视频| 国产精品久久久久免费a∨大胸| 成人高清视频观看www| 国产欧美精品一区二区| 成人黄色网免费| 欧美大片免费观看| 国产福利精品视频| 日韩视频欧美视频| 国产亚洲欧美另类中文| 黄色一区二区三区| 精品国产91久久久久久| 亚洲视频免费一区| 欧洲精品在线视频| 精品五月天久久| 国产成人综合精品| 国产精品第七影院| 国产精品露脸av在线| 亚洲一级免费视频| 亚洲一区国产精品| 亚洲第一偷拍网| 久久久精品影院| 欧美诱惑福利视频| 亚洲第一精品夜夜躁人人躁| 91av国产在线| 欧美一区二区三区……| 久久人91精品久久久久久不卡| 久久精品国产久精国产一老狼| 中文日韩在线观看| 欧美日韩亚洲激情| 国产精品视频1区| 国产精品精品久久久久久| 欧美影院在线播放| 欧美性xxxxx极品| 久久久噜噜噜久久久| 国产精品精品视频一区二区三区| 日韩精品高清在线观看| 97国产一区二区精品久久呦| 久久成人亚洲精品| 国产91精品最新在线播放| 日韩欧美精品网址| 美女av一区二区| 欧美成人精品不卡视频在线观看| 国产婷婷成人久久av免费高清| 中文字幕日韩视频| 久久久久久亚洲精品| 最新的欧美黄色| 亚洲第一精品夜夜躁人人爽| 国产日本欧美视频| 国产xxx69麻豆国语对白| 色婷婷亚洲mv天堂mv在影片| 九九精品视频在线| 国产99在线|中文| 欧美片一区二区三区| 精品久久久久国产| 国产乱人伦真实精品视频| 亚洲国产精品中文| 国产亚洲精品一区二区| 日韩免费不卡av| 日韩av手机在线看| 狠狠久久五月精品中文字幕| 成人www视频在线观看| 久久精品色欧美aⅴ一区二区| 亚洲国语精品自产拍在线观看| 91在线国产电影| 国产精品99久久久久久久久久久久| 亚洲人永久免费| 4388成人网| 中文字幕亚洲一区二区三区| 国产在线不卡精品| 欧美在线视频免费观看| 国产日产久久高清欧美一区| 日韩电视剧在线观看免费网站| 中文字幕日韩av综合精品| 国产精品午夜一区二区欲梦| 日韩精品亚洲元码| 91人成网站www| 92国产精品久久久久首页| 亚洲福利小视频| 国产69久久精品成人看| 成人免费看黄网站| 日韩免费电影在线观看| 国产欧美日韩中文字幕在线| 欧美制服第一页| 欧美午夜性色大片在线观看| 国产精品欧美日韩久久| 亚洲va国产va天堂va久久| 亚洲人成网在线播放| 亚洲欧美在线第一页| 成人精品视频久久久久| 亚洲欧美精品suv| 国产成人av在线| 国产午夜精品久久久| 久久久久日韩精品久久久男男| 日韩av免费在线看| 亚洲第一中文字幕在线观看| 国产91精品久久久久久| 中文字幕在线成人| 亚洲福利在线播放| 国产噜噜噜噜噜久久久久久久久| 91精品久久久久久久久久| 91wwwcom在线观看| 国产精品久久国产精品99gif| 国产精品极品美女在线观看免费| 精品久久久香蕉免费精品视频| 欧洲午夜精品久久久| 中文国产成人精品久久一| 欧美亚州一区二区三区| 一区二区三区视频观看| 亚洲欧美国产va在线影院| 日韩激情第一页| 国产精品扒开腿做爽爽爽的视频| 亚洲精品之草原avav久久| 国产成人涩涩涩视频在线观看|