JavaSript中變量的作用域閉包的深入理解
更新時間:2014年05月12日 10:36:02 作者:
js中的變量都是公用的沒有靜態(tài)變量,下面為大家介紹下變量的作用域閉包,需要的朋友可以參考下
復制代碼 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
/*
* 1.js中的變量都是公用的.
2.js中沒有靜態(tài)變量
3.閉包:函數內部可以調用函數外部的變量;反之,則不行
*/
var r=10;
function test1(){
var r2="abc";
//alert(r)
}
//alert(r2);//不能訪問的函數內部的r2
test1();
//嵌套的函數中也ok啦
function test2(num1){
function test3(num2,num3){
return num2+num3+num1;
}
return test3(10,20)
}
//alert(test2(30));
//---------循環(huán)中的閉包------------------------
function testfun(){
var r=1;
var arr=[];
for(var x=0;x<3;x++){
r++;
arr[x]=function(){
return r;
}
}
return arr;
}
alert("testfun:"+testfun());
var arr2=testfun();
alert("arr:"+arr2[0]);
alert("arr:"+arr2[1]());
alert("arr:"+arr2[2]());
//==========以上三個彈出框的結果都是4==========
/*分析原因:
理解一下在JavaScript中函數是什么?
函數就是一段可執(zhí)行的代碼塊,函數也是可以用一個變量表示,比如函數的第二種定義方式
var add=new Function("a","return a+10");底層的本質就是這個函數名指向
了這一段為變量而創(chuàng)建的可執(zhí)行的代碼。
* 首先當testfun函數執(zhí)行完畢以后,arr[0],arr[1],arr[]中都是存儲了相同的
可執(zhí)行代碼塊function(){
return r
}也就是說上面三個是函數變量而已,要執(zhí)行它們只需要在變量名稱后面加()就ok了
而且這個時候r的值4
當執(zhí)行arr[0]()相當于執(zhí)行了這個代碼塊中的代碼。
所以最終的結果return r,當然返回4了。
*/
</script>
</head>
<body>
</body>
</html>
相關文章
javascript 面向對象function詳解及實例代碼
這篇文章主要介紹了javascript 面向對象function詳解及實例代碼的相關資料,需要的朋友可以參考下2017-02-02微信小程序之滑動頁面隱藏和顯示組件功能的實現(xiàn)代碼
這篇文章主要介紹了微信小程序之滑動頁面隱藏和顯示組件功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06WEB 前端開發(fā)中防治重復提交的實現(xiàn)方法
這篇文章主要介紹了JS WEB 前端開發(fā)中防治重復提交的實現(xiàn)方法,涉及到表單提交的幾種方式介紹,非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-10-10JavaScript中document.querySelector函數用法介紹
這篇文章主要給大家介紹了關于JavaScript中document.querySelector函數用法的相關資料,document.querySelector是JavaScript中的一個內置方法,用于通過CSS選擇器選擇文檔中的第一個匹配元素,需要的朋友可以參考下2023-08-08