中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

詳解JavaScript中this關(guān)鍵字的用法
來源:易賢網(wǎng) 閱讀:1023 次 日期:2016-06-20 17:04:53
溫馨提示:易賢網(wǎng)小編為您整理了“詳解JavaScript中this關(guān)鍵字的用法”,方便廣大網(wǎng)友查閱!

this是函數(shù)內(nèi)部的對(duì)象并且被用于調(diào)用該函數(shù),this在全局中的使用非常之靈活,下面就帶大家來詳解JavaScript中this關(guān)鍵字的用法

this是函數(shù)內(nèi)部的一個(gè)特殊對(duì)象,this引用的是函數(shù)據(jù)以執(zhí)行的環(huán)境對(duì)象(關(guān)于環(huán)境對(duì)象我們會(huì)在文章最后作補(bǔ)充說明),在調(diào)用函數(shù)前this的值并不確定,不同的調(diào)用方式會(huì)導(dǎo)致this值的改變。

window.num = 22;

var o = {num: 11};

function sayNum(){

  alert(this.num)

}

sayNum();//22

o.sayNum = sayNum;

o.sayNum();//11

記住:函數(shù)名僅僅是一個(gè)包含指針的變量而已。因此即使是在不同的環(huán)境中執(zhí)行,全局的sayNum()函數(shù)與o.sayNum()指向的仍然是同一個(gè)函數(shù)。

1.全局作用域中調(diào)用函數(shù)時(shí)

全局作用域中調(diào)用,this對(duì)象引用的是window

匿名函數(shù)的執(zhí)行具有全局性,因此其this對(duì)象通常也指向window

function fn1(){

  console.log(this);

}

fn1();

2.通過new操作符調(diào)用

this引用的是實(shí)例對(duì)象

function Person(name){

  this.name = name;

}

Person.prototype.printName = function(){

  alert(this.name);//Byron

};

var p1 = new Person('Byron');

3.作為對(duì)象的方法調(diào)用

this引用的是該對(duì)象

var obj1 = {

  name: 'Byron',

  fn : function(){

    console.log(this);

  }

};

obj1.fn();

4.間接調(diào)用

call和apply

每個(gè)函數(shù)都包含兩個(gè)非繼承而來的方法:call()和apply()。這兩個(gè)方法的用途都是在特定的作用域中調(diào)用函數(shù),實(shí)際上等于設(shè)置函數(shù)體內(nèi)this對(duì)象的值。也就是說,直接調(diào)用函數(shù),調(diào)用時(shí)指定執(zhí)行環(huán)境是誰

window.color = 'red';

var o = {color: 'blue'};

function sayColor(){

  alert(this.color);

}

sayColor.call(this);//red

sayColor.call(window);//red

sayColor.call(o);//blue

(1)apply方法

接收兩個(gè)參數(shù),一個(gè)是在函數(shù)中運(yùn)行函數(shù)的作用域,另一個(gè)是參數(shù)數(shù)組。

(2)call方法

call方法與apply方法相同,區(qū)別在于接收參數(shù)的方式不同,對(duì)于call方法而言,第一個(gè)參數(shù)是this值沒有變化,變化的是其余參數(shù)都直接傳遞給函數(shù)。

function fn(){

   console.log(this)//windwow

   function InnerFn(){

     console.log(this)

   }

   InnerFn.call(this)//window

}

fn();

 function fn0(){

   console.log(this)//window

}

function fn1(){

   fn0.call(this);

   console.log(this);//window

}

fn1();

function fn0(){

 console.log(this)//object

}

var o = {

  fn1: function fn1(){

    fn0.call(this);

    console.log(this);//object

  }

}

o.fn1();  

5.bind方法

這個(gè)方法會(huì)創(chuàng)建一個(gè)函數(shù)的實(shí)例,其this值會(huì)被綁定到傳給bind()函數(shù)的值。也就是說會(huì)返回一個(gè)新函數(shù),并且使函數(shù)內(nèi)部的this為傳入的第一個(gè)參數(shù)

window.color = 'red';

var o = {color : 'blue'};

function sayColor(){

  alert(this.color)

}

var objectSayColor = sayColor.bind(o);

objectSayColor();//blue

補(bǔ)充說明:執(zhí)行環(huán)境定義

定義了變量或者函數(shù)有權(quán)訪問的其他數(shù)據(jù),每個(gè)執(zhí)行環(huán)境都有一個(gè)與之相關(guān)聯(lián)的變量對(duì)象,環(huán)境中定義的所有變量和函數(shù)都保存在這個(gè)對(duì)象中。我們編寫的代碼無法訪問這個(gè)對(duì)象,但解析器會(huì)在處理數(shù)據(jù)時(shí)在后臺(tái)使用它。

一、執(zhí)行環(huán)境的創(chuàng)建:

1.全局執(zhí)行環(huán)境

在web瀏覽器中,全局執(zhí)行環(huán)境被認(rèn)為是window對(duì)象,因此所有全局變量和函數(shù)都是作為window對(duì)象的屬性和方法創(chuàng)建的。代碼載入瀏覽器時(shí),全局執(zhí)行環(huán)境被創(chuàng)建(當(dāng)我們關(guān)閉網(wǎng)頁(yè)或者瀏覽器時(shí)全局執(zhí)行環(huán)境才被銷毀)。

2.局部執(zhí)行環(huán)境

每個(gè)函數(shù)都有自己的執(zhí)行環(huán)境,因此局部執(zhí)行環(huán)境為函數(shù)對(duì)象。當(dāng)函數(shù)被調(diào)用時(shí)函數(shù)的局部環(huán)境被創(chuàng)建(函數(shù)內(nèi)的代碼執(zhí)行完畢后,該環(huán)境被銷毀,同時(shí)保存在其中的所有變量和函數(shù)定義也隨之被銷毀)。

這個(gè)執(zhí)行環(huán)境以及相關(guān)的變量對(duì)象是個(gè)抽象的概念,解釋如下

var a = 1;

function fn(num1,num2){

  var b = 2;

  function fnInner(){

    var c = 3;

    alert(a + b + c);

  }

  fnInner();//fnInner調(diào)用時(shí)局部執(zhí)行環(huán)境創(chuàng)建

}

fn(4,5);//fn調(diào)用時(shí)局部執(zhí)行環(huán)境創(chuàng)建

名單

二、作用域鏈

javascript函數(shù)的執(zhí)行用到了作用域鏈,這個(gè)作用域鏈?zhǔn)呛瘮?shù)定義的時(shí)候創(chuàng)建的,當(dāng)定義一個(gè)函數(shù)時(shí),它實(shí)際保存一個(gè)作用域鏈。當(dāng)調(diào)用這個(gè)函數(shù)時(shí),它創(chuàng)建一個(gè)新的對(duì)象來存儲(chǔ)它的局部變量,并將這個(gè)對(duì)象添加至保存的作用域鏈。作用域鏈的前端始終都是當(dāng)前執(zhí)行的代碼所在環(huán)境的變量對(duì)象。作用域鏈的末端始終都是全局執(zhí)行環(huán)境的變量對(duì)象。作用域鏈的用途,是保證對(duì)執(zhí)行環(huán)境有權(quán)訪問的所有變量和函數(shù)的有權(quán)訪問

var scope = 'global scope';

function checkscope(){

  var scope = 'local scope';

  function f(){return scope};

  return f;

}

checkscope()();//local scope

理解:當(dāng)調(diào)用checkscope時(shí),函數(shù)f被定義并作為局部變量綁定到了checkscope作用域鏈上,因此函數(shù)f無論在哪里調(diào)用,這種綁定依然有效,因此返回值為local scope。

var num1 = 1;

function Outer(){

  var num2 = 2;

  console.log(num1 + num2);//3

  function Inner(){

    //這里可以訪問num3,num2,num1

    var num3 = 3;

    console.log(num1 + num2 + num3);//6

    }

  //這里可以訪問num2,Inner(),num1但不能訪問num3

  Inner();

}

Outer();

console.log(num1);//1,執(zhí)行環(huán)境

//這里只能訪問num1

作用域鏈(向上搜索):內(nèi)部環(huán)境可以通過作用域鏈訪問所有的外部環(huán)境,但外部環(huán)境不能訪問內(nèi)部環(huán)境中的任何變量和函數(shù)。

var name = 'Byron';

 function fn(){

   var name = 'Csper';

   console.log(name);//Casper

 }

 fn();

越往內(nèi)部的環(huán)境,變量權(quán)重越高。

注意:沒有帶var關(guān)鍵字直接聲明的變量屬于全局變量如直接聲明a = 1,此時(shí)的a為全局變量。

javscript引擎在進(jìn)入作用域時(shí),會(huì)對(duì)代碼分兩輪處理。第一輪,初始化變量。第二輪,執(zhí)行代碼

var a = 1;

function prison (a) {

  console.log(a);//1

  var a;

  console.log(a);//1

}

prison(1);

三、函數(shù)執(zhí)行

函數(shù)調(diào)用進(jìn)入執(zhí)行環(huán)境時(shí),首先處理arguments,初始化形參(默認(rèn)值為undefined),然后初始化函數(shù)內(nèi)的函數(shù)聲明,當(dāng)代碼一步一步執(zhí)行時(shí)再初始化函數(shù)內(nèi)的變量聲明(進(jìn)入環(huán)境未開始執(zhí)行代碼時(shí),值為undefined)。所以函數(shù)內(nèi)的初始化順序?yàn)樾螀ⅲ瘮?shù)聲明,變量聲明。可以從上圖圖一看出。下面我來舉個(gè)例子(整個(gè)全局環(huán)境也是函數(shù))。

alert(typeof fn);//function,函數(shù)聲明提前

alert(typeof fn0);//undefined,變量聲明提前但未賦值

function fn(){

//函數(shù)表達(dá)式

}

var fn0 = function(){

//函數(shù)定義式

}

alert(typeof fn0);//function,此時(shí)變量已被賦值

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:詳解JavaScript中this關(guān)鍵字的用法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲在线视频观看| 欧美中文字幕久久| 欧美日韩精品三区| 国产精品sm| 国产偷国产偷亚洲高清97cao| 狠狠色伊人亚洲综合成人| 亚洲国产成人av| 亚洲欧美激情精品一区二区| 久久不见久久见免费视频1| 欧美大色视频| 国产麻豆日韩欧美久久| 亚洲国产精品综合| 午夜一级在线看亚洲| 女女同性女同一区二区三区91| 欧美三级韩国三级日本三斤| 国产在线不卡| 亚洲视频axxx| 欧美大尺度在线观看| 国产美女精品| 亚洲精品一区二区三区不| 久久er99精品| 国产精品伦子伦免费视频| 亚洲欧洲午夜| 久久综合九色九九| 国产精品久久久久久久久搜平片| 在线播放日韩| 久久国产精品亚洲77777| 欧美日韩在线视频观看| 1000部国产精品成人观看| 亚洲欧美另类综合偷拍| 欧美久久久久久久久| 激情文学综合丁香| 午夜欧美不卡精品aaaaa| 欧美视频1区| 亚洲欧洲精品一区二区三区| 久久久亚洲人| 国产精品自拍小视频| 亚洲美女在线观看| 欧美1区免费| 欧美午夜宅男影院在线观看| 亚欧美中日韩视频| 亚洲国产另类精品专区| 欧美另类变人与禽xxxxx| 久久综合久久综合九色| 一区二区三区**美女毛片| 韩日成人av| 国产日韩欧美中文| 欧美日韩视频专区在线播放 | 亚洲国产国产亚洲一二三| 欧美伦理a级免费电影| 国产日韩专区在线| 欧美一区二区三区喷汁尤物| 国产精品一卡二| 性感少妇一区| 国产一区二区三区网站 | 欧美手机在线| 一区二区欧美视频| 欧美视频在线视频| 亚洲一级黄色片| 国产欧美日韩精品专区| 欧美与黑人午夜性猛交久久久| 国产婷婷色一区二区三区| 欧美在线亚洲一区| 激情亚洲成人| 欧美劲爆第一页| 亚洲私拍自拍| 国产精品一区二区三区成人| 欧美在线看片a免费观看| 激情成人在线视频| 欧美大片在线看| 中国女人久久久| 国产人久久人人人人爽| 久久精品中文字幕一区| 亚洲电影观看| 欧美日韩中文字幕精品| 亚洲专区免费| 影音先锋国产精品| 欧美视频在线播放| 久久精品国内一区二区三区| 在线成人h网| 欧美视频四区| 久久久久久久一区| 亚洲免费精彩视频| 国产精品人人爽人人做我的可爱 | 亚洲精品乱码久久久久久日本蜜臀 | 欧美精彩视频一区二区三区| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲综合色激情五月| 欧美色综合网| 久久国产精品亚洲77777| 国产精品久久午夜夜伦鲁鲁| 亚洲性夜色噜噜噜7777| 国内自拍亚洲| 欧美日本中文字幕| 久久精品五月婷婷| 亚洲精选一区| 国产日韩在线看片| 欧美激情综合色综合啪啪| 夜夜嗨av一区二区三区免费区| 国产精品中文在线| 欧美成人一区二区在线| 午夜精品福利一区二区蜜股av| 亚洲第一主播视频| 国产精品一二三视频| 欧美精品一区在线| 久久亚洲视频| 欧美亚洲视频一区二区| 亚洲理伦在线| 亚洲高清在线精品| 国产日韩在线视频| 国产精品久久久久久久久久ktv | 国产精品v欧美精品∨日韩| 欧美综合77777色婷婷| 一区二区成人精品| 亚洲国产天堂久久国产91| 国模吧视频一区| 国产精品一页| 国产精品久久久久久久第一福利| 蜜桃av久久久亚洲精品| 欧美专区18| 亚洲欧美www| 一区二区动漫| 亚洲精品乱码久久久久久按摩观| 韩国精品在线观看| 国产一区二区三区自拍| 国产精品久久久久77777| 欧美日韩国内| 欧美日本一道本| 欧美高清视频一二三区| 裸体歌舞表演一区二区| 久久精品中文字幕免费mv| 香蕉久久a毛片| 亚洲欧美电影在线观看| 亚洲午夜激情网站| 一区二区三区免费在线观看| 亚洲精品综合久久中文字幕| 亚洲激情电影在线| 亚洲黄色小视频| 91久久午夜| 亚洲美女区一区| 亚洲精选视频免费看| 亚洲精选视频免费看| 亚洲伦理精品| 一区二区三区免费在线观看| 一区二区三区福利| 中文久久精品| 亚洲欧美视频在线观看视频| 亚洲欧美日韩精品久久久| 亚洲专区一区二区三区| 亚洲欧美日韩另类精品一区二区三区| 亚洲影视综合| 久久福利视频导航| 麻豆久久婷婷| 欧美精品尤物在线| 欧美性大战xxxxx久久久| 国产精品日韩在线观看| 国产视频久久久久久久| 激情视频一区二区三区| 亚洲激情视频| 中文精品在线| 欧美在线视频观看| 久久综合久久综合九色| 欧美电影在线播放| 欧美性猛交99久久久久99按摩| 国产精品裸体一区二区三区| 国产视频不卡| 最近看过的日韩成人| 亚洲小少妇裸体bbw| 久久九九99| 欧美日韩八区| 国产日韩欧美高清免费| 亚洲二区在线| 亚洲一区二区三区激情| 久久蜜桃香蕉精品一区二区三区| 欧美成人午夜激情| 国产精品蜜臀在线观看| 好看的亚洲午夜视频在线| 最新国产の精品合集bt伙计| 亚洲一区二区免费视频| 久久欧美肥婆一二区| 国产精品h在线观看| 韩国一区电影| 亚洲无线观看| 美女黄网久久| 国产精品一区二区三区免费观看| 亚洲电影天堂av| 亚洲综合国产精品| 欧美电影在线观看完整版| 国产精品久久久999| 亚洲黄色av一区| 欧美一区二区在线播放| 欧美精品久久久久久久久久| 国产精品爽黄69| 亚洲精品国产精品国自产观看| 欧美一区二区三区免费在线看 | 久久嫩草精品久久久久| 欧美日韩中文字幕精品| 在线观看91精品国产入口| 亚洲综合99| 欧美日韩另类字幕中文|