手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaSript中变量的作用域闭包的深入理解
JavaSript中变量的作用域闭包的深入理解
摘要:复制代码代码如下:Inserttitlehere/**1.js中的变量都是公用的.2.js中没有静态变量3.闭包:函数内部可以调用函数外部的...

复制代码 代码如下:

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Insert title here</title>

<script type="text/javascript">

/*

* 1.js中的变量都是公用的.

2.js中没有静态变量

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));

//---------循环中的闭包------------------------

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中函数是什么?

函数就是一段可执行的代码块,函数也是可以用一个变量表示,比如函数的第二种定义方式

var add=new Function("a","return a+10");底层的本质就是这个函数名指向

了这一段为变量而创建的可执行的代码。

* 首先当testfun函数执行完毕以后,arr[0],arr[1],arr[]中都是存储了相同的

可执行代码块function(){

return r

}也就是说上面三个是函数变量而已,要执行它们只需要在变量名称后面加()就ok了

而且这个时候r的值4

当执行arr[0]()相当于执行了这个代码块中的代码。

所以最终的结果return r,当然返回4了。

*/

</script>

</head>

<body>

</body>

</html>

【JavaSript中变量的作用域闭包的深入理解】相关文章:

JavaScript中的bold()方法使用详解

JavaScript中反正弦函数Math.asin()的使用简介

JavaScript中strike()方法的使用介绍

JavaScript中的函数嵌套使用

关于JavaScript作用域你想知道的一切

javascript中动态函数用法

详解JavaScript中void语句的使用

JavaScript中getUTCMinutes()方法的使用详解

JavaSacript中charCodeAt()方法的使用详解

JavaScript对W3C DOM模版的支持情况详解

精品推荐
分类导航