js 匿名函数和闭包函数(js练习)

一、闭包的定义:闭包说白了就是函数的嵌套,内层的函数可以使用外层函数的所有变量,即使外层函数已经执行完毕(这点涉及JavaScript作用域链)。


二、闭包的练习代码

1、首先(保证页面引入了jQuery)创建

window.document.body.innerHTML="<p>开始练习document对象</p>"



2、js创建ul和li标签,并且添加ul标签在body里面


var UL1=jQuery("<ul>,{name:'ul1'}");
UL1.appendTo(window.document.body);
var Li1=jQuery("<li>",{value:'01',text:'01li'});
var Li2=jQuery("<li>",{value:'02',text:'02li'});
var Li3=jQuery("<li>",{value:'03',text:'03li'});

 

Li1.appendTo(document.body.getElementsByTagName("ul"));
Li2.appendTo(document.body.getElementsByTagName("ul"));								                   			  Li3.appendTo(document.body.getElementsByTagName("ul"));


 
 

3、若执行下面的代码:

var Lis = document.getElementsByTagName("li");//找到Li标签
function showAllLi(){for(var i = 0 ; i <Lis.length ; i++)
{
Lis[i].onclick = function(){console.log(i,$(Lis[i]).text())}
}}


 本想挨个输出Lis[0] 、Lis[1] 、Lis[2] 的值,但是最终结果却是: 
VM30474:3 ""
三个都是一样的结果,原来i变量已经被加到了3;

(运用立即函数,不带返回值的情况):

for(var i = 0 ; i <Lis.length ; i++)
{
Lis[i].onclick = (function(i){ console.log($(Lis[i]).text()) })(i)
}


 
 得到的结果是,立即分别输出了三个<li>标签的内容; 

但是,值得注意的是:<li>标签在chrome浏览器中,立即执行函数却并未绑定到click事件;

解决办法一(Reference1):

for(var i = 0 ; i <Lis.length ; i++){
(function(i){
 Lis[i].onclick = function(){
return function(){
console.log($(Lis[i]).text())
}
}
})(i)
}



解决办法二:

for(var i = 0 ; i <Lis.length ; i++)
{
Lis[i].onclick = function(){ console.log($(this).text()) }
}






Reference:

1、http://www.360doc.com/content/15/0615/09/10504424_478206402.shtml

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值