|
一、this指向構(gòu)造函數(shù)實(shí)例化對象
在上篇文章中,我們提到了使用new和不使用new調(diào)用構(gòu)造函數(shù)的區(qū)別,如下例:
復(fù)制代碼 代碼如下:
function Benjamin(username, sex) {
this.username = username;
this.sex = sex;
}
var benjamin = new Benjamin("zuojj", "male");
//Outputs: Benjamin{sex: "male",username: "zuojj"}
console.log(benjamin);
var ben = Benjamin("zhangsan", "female");
//Outputs: undefined
console.log(ben);
當(dāng)構(gòu)造函數(shù)當(dāng)做普通函數(shù)被調(diào)用時,并沒有返回值,同時this指向全局對象。那么我們?nèi)绾蝸肀苊庖驗(yàn)槿鄙賜ew關(guān)鍵字,而產(chǎn)生的問題呢?
復(fù)制代碼 代碼如下:
function Benjamin(username, sex) {
//Check whether "this" is a "Benjamin" object
if(this instanceof Benjamin) {
this.username = username;
this.sex = sex;
}else {
return new Benjamin(username, sex);
}
}
var benjamin = new Benjamin("zuojj", "male");
//Outputs: Benjamin{sex: "male",username: "zuojj"}
console.log(benjamin);
var ben = Benjamin("zhangsan", "female");
//Outputs: Benjamin {username: "zhangsan", sex: "female"}
console.log(ben);
在上例中,我們首先檢查this是否是Benjammin的實(shí)例,如果不是,使用new自動調(diào)用構(gòu)造函數(shù),并實(shí)例化,這意味著,我們不再需要擔(dān)心,遺漏new關(guān)鍵字實(shí)例化構(gòu)造函數(shù)。當(dāng)然這樣我們可能會養(yǎng)成一個壞的習(xí)慣,如果避免這種現(xiàn)象呢?我們可以拋出一個錯誤,像下面這樣:
復(fù)制代碼 代碼如下:
function Benjamin(username, sex) {
//Check whether "this" is a "Benjamin" object
if(this instanceof Benjamin) {
this.username = username;
this.sex = sex;
}else {
// If not, throw error.
throw new Error("`Benjamin` invoked without `new`");
}
}
二、this指向調(diào)用該函數(shù)的對象
看下面的例子:
復(fù)制代碼 代碼如下:
var x = 10;
var obj = {
x: 10,
output: function() {
//Outputs: true
console.log(this === obj);
return this.x;
},
innerobj: {
x: 30,
output: function() {
//Outputs: true
console.log(this === obj.innerobj);
return this.x;
}
}
};
//Outputs: 10
console.log(obj.output());
//Outputs: 30
console.log(obj.innerobj.output());
三、this指向全局對象
在上面討論構(gòu)造函數(shù)的時候我們也討論到不適用new的時候,this會指向全局對象,下面我們來看看兩種常見的容易犯錯的實(shí)例:
復(fù)制代碼 代碼如下:
var x = 100;
var obj = {
x: 10,
output: function() {
(function() {
//Outputs: true
console.log(this === window);
//Outputs: Inner: 100
console.log("Inner:" + this.x);
})();
return this.x;
}
};
//Outputs: 10
console.log(obj.output());
在使用閉包的時候,作用域發(fā)生變化,this指向window(瀏覽器中)。
復(fù)制代碼 代碼如下:
var x = 100;
var obj = {
x: 10,
output: function() {
return this.x;
}
};
var output = obj.output;
//Outputs: 10
console.log(obj.output());
//Outputs: 100
console.log(output());
var obj2 = {
x: 30,
output: obj.output
}
//Outputs: 30
console.log(obj2.output());
此時this始終指向函數(shù)調(diào)用時的對象。
四、this指向apply/call()方法指派的對象
復(fù)制代碼 代碼如下:
var x = 100;
var obj = {
x: 10,
output: function() {
return this.x;
}
};
//Outputs: 10
console.log(obj.output());
var obj2 = {
x: 40,
output: obj.output
}
//Outputs: 40
console.log(obj.output.call(obj2));
//Outputs: 10
console.log(obj2.output.apply(obj));
五、callback函數(shù) 主站蜘蛛池模板: 91丝袜美腿高跟国产极品老师 | 99精品久久99久久久久久 | 欧美另类xxx | 奇米影视狠狠干 | 成年人免费在线视频网站 | 怎么看毛片| 欧美成人日韩 | 欧美一级欧美一级高清 | 国产女人视频免费观看 | 成人免费在线观看视频 | 一区二区三区视频免费 | 日本三级一区二区三区 | 欧美白人猛性xxxxx交69 | 日韩免费视频一区二区 | 久久99国产精品久久99软件 | 四虎现在的网址入口2022 | 国产福利91 | 美女一级毛片免费看看 | 亚洲精品国产综合一线久久 | 国产成人精品午夜二三区 | 欧美色欧美亚洲高清在线观看 | 国产色综合一区二区三区 | 亚洲免费色视频 | 小说区图片区视频区 | 久久亚洲精品国产精品婷婷 | 网站久久 | 午夜爱 | 欧美一区二区三区精品国产 | heyzo国产亚洲高清 | 亚洲免费视频一区 | 国产成人啪精品视频免费网站软件 | 亚洲欧美一区二区三区麻豆 | 伊色综合久久之综合久久 | 欧美激情视频二区 | 亚洲麻豆视频 | 97影院秋霞国产精品 | 精品成人免费播放国产片 | 2021中国大陆精品视频xxxx | 久久精品中文字幕首页 | 麻豆精品密在线观看 | 美女很黄很黄是免费的 |