js闭包的与非闭包的对比

项目目录结构


     cosure.js的代码如下:
 
//闭包
function test(){
	var arr = [];
	for (var i = 0; i < 10; i++) {
		//闭包的写法就是  一个圆括号里面包了一个匿名函
		//  把需要保存的值,通过参数传递
		(    
			function(j)
			{
				arr[j] =  function(){
						document.write(j + " ");
				}
			}(i)
		)
	}
	return arr;
}
var myArr = test();
for (var i = 0; i < 10; i++) {
	myArr[i]();
}

    闭包的代码

    cosure.html代码如下:
    
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script src="js/cosure.js"></script>
</head>
<body>
</body>
</html>
    运行的效果如下:
    



 ---------------------------------分割线--------------------------------------

     非闭包的代码

     uncosure.js的代码如下:
     
//非闭包的情况
function test(){
	var arr = [];
	for (var i = 0; i < 10; i++) {
		arr[i] =  function(){
				document.write(i + " ");
		}
	}
	return arr;
}
var myArr = test();
for (var i = 0; i < 10; i++) {
	myArr[i]();
}
     uncosure.html的代码如下:
     
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script src="js/uncosure.js"></script>


</head>
<body>
	
</body>
</html>
    运行如下:

闭包与非闭包,闭包实现循环给两个按钮绑定事件,并alert当选for循环的index值(相关代码array.js和array.html)

界面如下:

1.闭包btn

     array.js  如下:

function bindBtn() {
    var btnArr = new Array();
    for (var i = 1; i <= 2; i++) {
        btnArr[i] = document.getElementById("btn" + i);
        (
        	function(obj,index){  //闭包函数绑定事件
	        	obj.onclick = function(){
	        	    alert("百度经验" + index );
	        	}
            }(btnArr[i],i)
        )
    }
    // alert(btnArr);
    console.log(btnArr, "obj");
    console.log(btnArr.constructor, "constructor"); //ƒ Array() { [native code] }
    console.log(btnArr.prototype, "prototype");
}

window.onload = function() {

	 unbindBtn();
    //bindBtn();

}
    array.html
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>

</head>
<body>

	<button id="btn1">btn1</button>
	<button id="btn2">btn2</button>
	
	<script src="js/array.js"></script>
</body>
</html>

    点击 btn1

    

     点击 btn2



2.非闭包btn

     array.html如上。
     
     array.js代码如下:
    
function bindBtn() {
    var btnArr = new Array();
    for (var i = 1; i <= 2; i++) {
        btnArr[i] = document.getElementById("btn" + i);
        (
        	function(obj,index){  //闭包函数绑定事件
	        	obj.onclick = function(){
	        	    alert("百度经验" + index );
	        	}
            }(btnArr[i],i)
        )
    }
    // alert(btnArr);
    console.log(btnArr, "obj");
    console.log(btnArr.constructor, "constructor"); //ƒ Array() { [native code] }
    console.log(btnArr.prototype, "prototype");
}
window.onload = function() {

	// unbindBtn();
    bindBtn();

}

    点击 btn1

    

     点击 btn2

  








  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

q1054261752

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值