国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

關于this和self的使用說明_javascript技巧

來源:懂視網 責編:小采 時間:2020-11-27 20:54:29
文檔

關于this和self的使用說明_javascript技巧

關于this和self的使用說明_javascript技巧:前兩天在寫一個chrome的extensions,因為 content里和background交互必需要一個異步方法實現,如: 代碼如下: var Test = new Class({ options: {}, initialize: function(args) { chrome.extension.sendReques
推薦度:
導讀關于this和self的使用說明_javascript技巧:前兩天在寫一個chrome的extensions,因為 content里和background交互必需要一個異步方法實現,如: 代碼如下: var Test = new Class({ options: {}, initialize: function(args) { chrome.extension.sendReques

前兩天在寫一個chrome的extensions,因為 content里和background交互必需要一個異步方法實現,如:
代碼如下:
var Test = new Class({
options: {},
initialize: function(args) {
chrome.extension.sendRequest({ 'type':'options' }, function(options) {
this.options = options;
……
});
}
});

這個this應該是Test這個對象,但是回調方法里是空的。難道要把this做參數傳過去,再call回來?還好,mootools里有個好方法,bind。
代碼如下:
var Test = new Class({
options: {},
initialize: function(args) {
chrome.extension.sendRequest({ 'type':'options' }, function(options) {
this.options = options;
……
}.bind(this));
}
});

這下OK了,繼續寫:
代碼如下:
var Test = new Class({
options: {},
initialize: function(args) {
chrome.extension.sendRequest({ 'type':'options' }, function(options) {
this.options = options;
$each(this.options, function(o, i) {
if (o == '1') {
this.fun1();
} else {
this.fun2();
}
}.bind(this));
}.bind(this));
},
fun1: function {},
fun2: function {}
});

就算有bind也不容易分清哪個this是什么了。而真實的代碼比這個要恐怖的多,有的情況下,我們的確需要this指向其它的變量,而不是這個類。
最常用的解決方法,是這樣:
代碼如下:
var Test = new Class({
options: {},
initialize: function(args) {
var _self = this;
chrome.extension.sendRequest({ 'type':'options' }, function(options) {
_self.options = options;
$each(_self.options, function(o, i) {
if (o == '1') {
_self.fun1();
} else {
_self.fun2();
}
});
});
},
fun1: function {},
fun2: function {}
});

我特別定義了一個_self的變量來代替this,這看起來象什么?python!
現在終于體會到python的self絕對不是多此一舉。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

關于this和self的使用說明_javascript技巧

關于this和self的使用說明_javascript技巧:前兩天在寫一個chrome的extensions,因為 content里和background交互必需要一個異步方法實現,如: 代碼如下: var Test = new Class({ options: {}, initialize: function(args) { chrome.extension.sendReques
推薦度:
標簽: js javascript this
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 免费一级 一片一毛片 | 精品视频在线观看免费 | 毛片一区二区三区 | 国产高清精品一级毛片 | 国产综合一区二区 | 国产精品免费精品自在线观看 | 国产欧美一区二区三区鸳鸯浴 | 中文字幕日韩有码 | 亚洲情a成黄在线观看动 | 国产午夜视频在线观看 | 国产福利久久青青草原下载 | 亚洲精品成人久久 | 国产高清一区二区三区视频 | 天码毛片一区二区三区入口 | 久久伊人五月天 | 亚洲精品制服丝袜二区 | 国产观看 | 欧美综合图区亚洲综合图区 | 日韩精品123 | 久久国产热 | 亚洲精品成人久久久影院 | 国产精美视频 | 国产一区二区久久久 | 视频精品一区二区 | 永久免费观看的毛片的网站 | 免费一级毛片视频 | 久久www免费人成_看片美女图 | 成人区精品一区二区毛片不卡 | 亚洲欧美日韩精品 | 91福利一区二区三区 | 国产特级全黄一级毛片不卡 | 在线99视频 | 免费观看a毛片一区二区不卡 | 国产精品久久久久久久久久免费 | 国产高清精品一区 | 日韩免费一区 | 成人久久久 | 欧美专区日韩专区 | 亚洲男女网站 | 国产自在线拍 | 日韩精品小视频 |