JavaScript靜態(tài)作用域和動態(tài)作用域?qū)嵗斀?/h1>
更新時間:2019年06月17日 09:41:29 作者:萌面大蝦
這篇文章主要介紹了JavaScript靜態(tài)作用域和動態(tài)作用域的實例代碼,本文通過文字實例代碼相結(jié)合的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
靜態(tài)作用域指的是一段代碼,在它執(zhí)行之前就已經(jīng)確定了它的作用域,簡單來說就是在執(zhí)行之前就確定了它可以應用哪些地方的作用域(變量)。
動態(tài)作用域–函數(shù)的作用域是在函數(shù)調(diào)用的時候才決定的
JavaScript采用的是詞法作用域即靜態(tài)作用域;
// 靜態(tài)作用域:
var a = 10;
function fn() {
var b = 1;
console.log(a + b);
}
fn(); // 11
在創(chuàng)建fn函數(shù)時的時候就已經(jīng)確定了它可以作用哪些變量,如果函數(shù)fn里面有變量a就直接操作變量a,
如果沒有就往上一級查找,這就是靜態(tài)作用域
// 動態(tài)作用域:
function foo() {
console.log(a);
}
function bar() {
var a = 3;
foo();
}
var a = 2;
bar(); // 2;
bar 調(diào)用,bar里面foo被調(diào)用,foo函數(shù)需要查找變量a,由于JavaScript是詞法作用域(即靜態(tài)作用域),foo被解析時在全局作用域.
所以只能在全局作用域中找a,輸出結(jié)果為2,而非bar作用域中的a。如果js采用的時動態(tài)作用域,那么foo在bar中調(diào)用,就會先在bar中查詢a,輸出為3。
ps:下面看下JavaScript之靜態(tài)作用域
作用域是指代碼中定義變量的區(qū)域。作用域規(guī)定了如何查找變量,也就是確定當前代碼對變量的訪問權(quán)限。
靜態(tài)作用域和動態(tài)作用域
靜態(tài)作用域是指函數(shù)的作用域在函數(shù)定義時就已經(jīng)確定了,而動態(tài)作用域是指函數(shù)的作用域在運行時才確定。下面是一段代碼:
var value = 1;
function foo() {
console.log(value);
}
function bar() {
var value = 2;
foo();
}
bar();
如果這段代碼使用靜態(tài)作用域的方式訪問變量,那么執(zhí)行foo()函數(shù)時,首先查看函數(shù)內(nèi)是否存在局部變量value的定義,如果沒有,則查找之前的代碼,也就是var value = 1;,查找到了value的定義為1,因此輸出1。
如果這段代碼使用動態(tài)作用域的方式訪問變量,那么執(zhí)行foo()函數(shù)時,首先依舊從函數(shù)內(nèi)部查找是否存在局部變量value的定義,如果沒有,那么從調(diào)用方bar()函數(shù)的作用域中查找,找到了var value = 2;,因此輸出2。
JavaScript采用靜態(tài)作用域的方式訪問變量,因此這個例子輸出為1。
常見的采用動態(tài)作用域的語言是bash。
相關(guān)文章
-
Bootstrap3 input輸入框插入glyphicon圖標的方法
這篇文章主要介紹了Bootstrap3 input輸入框插入glyphicon圖標的方法的相關(guān)資料,需要的朋友可以參考下 2016-05-05
-
基于JavaScript FileReader上傳圖片顯示本地鏈接
這篇文章主要為大家詳細介紹了基于JavaScript FileReader上傳圖片顯示本地鏈接的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下 2016-05-05
最新評論
靜態(tài)作用域指的是一段代碼,在它執(zhí)行之前就已經(jīng)確定了它的作用域,簡單來說就是在執(zhí)行之前就確定了它可以應用哪些地方的作用域(變量)。
動態(tài)作用域–函數(shù)的作用域是在函數(shù)調(diào)用的時候才決定的
JavaScript采用的是詞法作用域即靜態(tài)作用域;
// 靜態(tài)作用域:
var a = 10;
function fn() {
var b = 1;
console.log(a + b);
}
fn(); // 11
在創(chuàng)建fn函數(shù)時的時候就已經(jīng)確定了它可以作用哪些變量,如果函數(shù)fn里面有變量a就直接操作變量a,
如果沒有就往上一級查找,這就是靜態(tài)作用域
// 動態(tài)作用域:
function foo() {
console.log(a);
}
function bar() {
var a = 3;
foo();
}
var a = 2;
bar(); // 2;
bar 調(diào)用,bar里面foo被調(diào)用,foo函數(shù)需要查找變量a,由于JavaScript是詞法作用域(即靜態(tài)作用域),foo被解析時在全局作用域.
所以只能在全局作用域中找a,輸出結(jié)果為2,而非bar作用域中的a。如果js采用的時動態(tài)作用域,那么foo在bar中調(diào)用,就會先在bar中查詢a,輸出為3。
ps:下面看下JavaScript之靜態(tài)作用域
作用域是指代碼中定義變量的區(qū)域。作用域規(guī)定了如何查找變量,也就是確定當前代碼對變量的訪問權(quán)限。
靜態(tài)作用域和動態(tài)作用域
靜態(tài)作用域是指函數(shù)的作用域在函數(shù)定義時就已經(jīng)確定了,而動態(tài)作用域是指函數(shù)的作用域在運行時才確定。下面是一段代碼:
var value = 1;
function foo() {
console.log(value);
}
function bar() {
var value = 2;
foo();
}
bar();
如果這段代碼使用靜態(tài)作用域的方式訪問變量,那么執(zhí)行foo()函數(shù)時,首先查看函數(shù)內(nèi)是否存在局部變量value的定義,如果沒有,則查找之前的代碼,也就是var value = 1;,查找到了value的定義為1,因此輸出1。
如果這段代碼使用動態(tài)作用域的方式訪問變量,那么執(zhí)行foo()函數(shù)時,首先依舊從函數(shù)內(nèi)部查找是否存在局部變量value的定義,如果沒有,那么從調(diào)用方bar()函數(shù)的作用域中查找,找到了var value = 2;,因此輸出2。
JavaScript采用靜態(tài)作用域的方式訪問變量,因此這個例子輸出為1。
常見的采用動態(tài)作用域的語言是bash。
相關(guān)文章
Bootstrap3 input輸入框插入glyphicon圖標的方法
這篇文章主要介紹了Bootstrap3 input輸入框插入glyphicon圖標的方法的相關(guān)資料,需要的朋友可以參考下2016-05-05
基于JavaScript FileReader上傳圖片顯示本地鏈接
這篇文章主要為大家詳細介紹了基于JavaScript FileReader上傳圖片顯示本地鏈接的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05

