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

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

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

函數(shù)本身也是一個值,也有自己的作用域。它的作用域與變量一樣,就是其聲明時所在的作用域,與其運行時所在作用域無關(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不會到函數(shù)f體內(nèi)取值,所以輸出1,而不是2。

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

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)致報錯。

同樣的函數(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ù)的作用域,是和父級上下文綁定在一起的

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

 
obj.show() // undefined

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

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

obj.show()() // 2

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

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

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

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

相關(guān)文章

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

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

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

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

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

    純js簡單日歷實現(xiàn)代碼

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

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

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

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

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

    JavaScript中的this引用(推薦)

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

    innerHTML在IE中報錯解決方案

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

    原生Javascript插件開發(fā)實踐

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

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

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

    JS解決ie6下png透明的方法實例

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

最新評論