function Benjamin(username, sex) {
this.username = username;
this.sex = sex;
} " /> 精品无码久久久久久国产,国产一区二区三区在线,黄a在线观看

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

Javascript this 關(guān)鍵字 詳解

一、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)绾蝸肀苊庖驗槿鄙賜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ù)

主站蜘蛛池模板: 精品国产欧美一区二区 | 99综合| 爱综合 | 久久69精品久久久久久国产越南 | 亚洲国产精品久久久 | 亚洲精品一区二区三区丝袜 | 亚洲欧美日韩网站 | 成人精品一区 | 欧美一级一 | 国产精品99久久久久久宅男 | 中文字幕一区二区三区精彩视频 | 成人精品区 | 欧美大片一区 | 久久y| 久久久久久久香蕉 | 九九热精品视频在线观看 | 黄色中文字幕 | 国产成人精品一区二三区在线观看 | 99精品视频一区二区三区 | 国产精品久久久久久久久免费樱桃 | 亚洲一区二区三区免费视频 | 色噜噜狠狠色综合中国 | 天堂久久网 | 成人毛片在线观看 | 欧区一欧区二欧区三免费 | 中文字幕在线看人 | 伊人免费在线观看 | 欧美嘿咻 | a黄视频| www天天操| 欧美激情综合 | 中文av在线播放 | www.色综合| 国产在线资源 | 国产小视频在线 | 久久精品国产一区二区电影 | 欧美性受 | 欧美日本韩国一区二区 | 亚洲精品一区二区三区丝袜 | 国产在线视频一区二区 | 久久大陆 |