欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于this和self的使用說(shuō)明

 更新時(shí)間:2010年08月01日 17:41:12   作者:  
剛接觸python的時(shí)候,最不習(xí)慣的事情,就是每個(gè)方法都要加一個(gè)self。無(wú)論Javascript還是C#,都直接一個(gè)this搞定,干嘛非要加一個(gè)變量self。
前兩天在寫(xiě)一個(gè)chrome的extensions,因?yàn)?content里和background交互必需要一個(gè)異步方法實(shí)現(xiàn),如:
復(fù)制代碼 代碼如下:

var Test = new Class({
options: {},
initialize: function(args) {
chrome.extension.sendRequest({ 'type':'options' }, function(options) {
this.options = options;
……
});
}
});

這個(gè)this應(yīng)該是Test這個(gè)對(duì)象,但是回調(diào)方法里是空的。難道要把this做參數(shù)傳過(guò)去,再call回來(lái)?還好,mootools里有個(gè)好方法,bind。
復(fù)制代碼 代碼如下:

var Test = new Class({
options: {},
initialize: function(args) {
chrome.extension.sendRequest({ 'type':'options' }, function(options) {
this.options = options;
……
}.bind(this));
}
});

這下OK了,繼續(xù)寫(xiě):
復(fù)制代碼 代碼如下:

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也不容易分清哪個(gè)this是什么了。而真實(shí)的代碼比這個(gè)要恐怖的多,有的情況下,我們的確需要this指向其它的變量,而不是這個(gè)類(lèi)。
最常用的解決方法,是這樣:
復(fù)制代碼 代碼如下:

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 {}
});

我特別定義了一個(gè)_self的變量來(lái)代替this,這看起來(lái)象什么?python!
現(xiàn)在終于體會(huì)到python的self絕對(duì)不是多此一舉。

相關(guān)文章

最新評(píng)論