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

JS函數(shù)本身的作用域?qū)嵗治?/h1>
 更新時(shí)間:2020年03月16日 09:42:20   作者:wangliang_001  
這篇文章主要介紹了JS函數(shù)本身的作用域,結(jié)合實(shí)例形式分析了JS函數(shù)作用域相關(guān)原理、操作技巧與使用注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了JS函數(shù)本身的作用域。分享給大家供大家參考,具體如下:

函數(shù)本身也是一個(gè)值,也有自己的作用域。它的作用域與變量一樣,就是其聲明時(shí)所在的作用域,與其運(yùn)行時(shí)所在作用域無(wú)關(guān)。

var a = 1
var x = function() {
 console.log(a)
}

function f() {
 var a = 2
 x()
}

f()

上面代碼中,函數(shù)x是在函數(shù)f的外部聲明的,所以它的作用域綁定外層,內(nèi)部變量a不會(huì)到函數(shù)f體內(nèi)取值,所以輸出1,而不是2。

總之,函數(shù)執(zhí)行時(shí)所在的作用域,是定義時(shí)的作用域,而不是調(diào)用時(shí)所在的作用域

var x = function () {
 console.log(a);
};

function y(f) {
 var a = 2;
 f();
}

y(x)
// ReferenceError: a is not defined

上面代碼將函數(shù)x作為參數(shù),傳入函數(shù)y。但是x是在函數(shù)y體外聲明的,作用域綁定外層,因此找不到函數(shù)y的內(nèi)部變量a,導(dǎo)致報(bào)錯(cuò)。

同樣的函數(shù)本內(nèi)部聲明的函數(shù),作用域綁定在函數(shù)體內(nèi)部

function foo() {
 var x = 1;
 function bar () {
 console.log(x)
 }
 return bar
}
var x = 2 
var f = foo()
f() // 1

箭頭函數(shù)的作用域,是和父級(jí)上下文綁定在一起的

var obj = {
 id: 1,
 show: () => {
 console.log(this.id)
 }
}

 
obj.show() // undefined

上面代碼show函數(shù)是一個(gè)箭頭函數(shù),其this指向父級(jí),而父級(jí)是一個(gè)頂級(jí)對(duì)象,window,window.id沒(méi)有定義,所以返回undefined

var obj = {
 id: 2,
 show: function() {
 return () => {
  console.log(this.id)
 }
 }
}

obj.show()() // 2

上面代碼中,箭頭函數(shù)定義在show函數(shù)內(nèi)部,其父級(jí)作用域?yàn)閟how函數(shù)的作用域,show函數(shù)中this指向調(diào)用show函數(shù)的對(duì)象,即obj,obj中有id屬性,且值為2,所以輸出2

感興趣的朋友可以使用在線(xiàn)HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專(zhuān)題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 微信小程序如何調(diào)用json數(shù)據(jù)接口并解析

    微信小程序如何調(diào)用json數(shù)據(jù)接口并解析

    這篇文章主要介紹了微信小程序如何調(diào)用json數(shù)據(jù)接口并解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-06-06
  • JavaScript、C# URL編碼、解碼總結(jié)

    JavaScript、C# URL編碼、解碼總結(jié)

    這篇文章主要介紹了JavaScript、C# URL編碼總結(jié),注意包括了encodeURI、decodeURI、encodeURIComponent、decodeURIComponent等使用需要的朋友可以參考下
    2017-01-01
  • 純js簡(jiǎn)單日歷實(shí)現(xiàn)代碼

    純js簡(jiǎn)單日歷實(shí)現(xiàn)代碼

    日歷想必大家都比較熟悉吧,實(shí)現(xiàn)的方法有很多種,在本文大家將學(xué)會(huì)到如何使用js簡(jiǎn)單實(shí)現(xiàn)日歷,感興趣的朋友可以了解下
    2013-10-10
  • js動(dòng)態(tài)創(chuàng)建標(biāo)簽示例代碼

    js動(dòng)態(tài)創(chuàng)建標(biāo)簽示例代碼

    這篇文章主要以示例的方式為大家介紹下js如何動(dòng)態(tài)創(chuàng)建標(biāo)簽,需要的朋友可以參考下
    2014-06-06
  • JS中async/await實(shí)現(xiàn)異步調(diào)用的方法

    JS中async/await實(shí)現(xiàn)異步調(diào)用的方法

    這篇文章主要介紹了async/await實(shí)現(xiàn)異步調(diào)用的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08
  • JavaScript中的this引用(推薦)

    JavaScript中的this引用(推薦)

    this是javascript的一個(gè)關(guān)鍵字,隨著函數(shù)使用場(chǎng)合不同,this的值會(huì)發(fā)生變化。這篇文章主要介紹了JavaScript中的this引用的相關(guān)資料,非常不錯(cuò),需要的朋友可以參考下
    2016-08-08
  • innerHTML在IE中報(bào)錯(cuò)解決方案

    innerHTML在IE中報(bào)錯(cuò)解決方案

    這篇文章主要介紹了innerHTML在IE中報(bào)錯(cuò)解決方案,需要的朋友可以參考下
    2014-12-12
  • 原生Javascript插件開(kāi)發(fā)實(shí)踐

    原生Javascript插件開(kāi)發(fā)實(shí)踐

    本文主要介紹了原生Javascript插件開(kāi)發(fā)實(shí)踐思路與代碼,具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • 微信小程序開(kāi)發(fā)之map地圖實(shí)現(xiàn)教程

    微信小程序開(kāi)發(fā)之map地圖實(shí)現(xiàn)教程

    相信大家現(xiàn)在都知道微信小程序吧,下面這篇文章主要給大家介紹了微信小程序開(kāi)發(fā)之map地圖的相關(guān)資料,分享出來(lái)供大家參考學(xué)習(xí),文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-06-06
  • JS解決ie6下png透明的方法實(shí)例

    JS解決ie6下png透明的方法實(shí)例

    解決ie6下png透明的問(wèn)題想必前端都比較清楚,雖然有很多方法,但是我覺(jué)得用JS還是最省事的方法,不管是圖片還是背景圖片都OK。
    2013-08-08

最新評(píng)論