博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript闭包的应用案例——让Onclick事件都能正确的弹出相应的参数
阅读量:6094 次
发布时间:2019-06-20

本文共 1403 字,大约阅读时间需要 4 分钟。

摘转自:http://www.cnblogs.com/rubylouvre/archive/2009/07/24/1530074.html

要求:让这三个节点的Onclick事件都能正确的弹出相应的参数。

  • aa
  • aa
  • aa

问题:

onclick的绑定函数 function(){alert(i)}的作用域为对应li对象,它里面alert的i的作用域为window,每次循环都是在重写window.i的值,因此循环完,i已是4,点击哪一个li元素都是4

解决方法1:利用闭包(closure)

var lists = document.getElementsByTagName("li");for(var i=0,l=lists.length; i < l; i++){  lists[i].onclick = (function(i){
//保存于外部函函数 return function(){ alert(i); } })(i);}

var lists = document.getElementsByTagName("li");for(var i=0,l=lists.length; i < l; i++){  lists[i].onclick = new function(){    var t = i;    return function(){      alert(t+1)    }  }}

解决方法2:利用事件代理

var ul = document.getElementsByTagName("ul")[0];ul.onclick = function(){  var e = arguments[0] || window.event,  target = e.srcElement ? e.srcElement : e.target;  if(target.nodeName.toLowerCase() == "li"){    alert(target.id.slice(-1))  }}

解决方法3:将暂时变量保留于元素节点上。

var lists = document.getElementsByTagName("li");for(var i=0,t=0,el; el = list[i++];){  el.i = t++  el.onclick = function(){    alert(this.i)  }}

解决方法4:使用with语句造成的对象闭包。

var els = document.getElementsByTagName("li")for(var i=0,n=els.length;i

解决方法5:使用try...catch语句构造的异常闭包

var lists = document.getElementsByTagName("li");for(var i=0,l=lists.length; i < l; i++){  try{    throw i;  }catch(i){    lists[i].onclick =  function(){      alert(i)    }  }}

评价:牛人就是牛人,我打死也想不到这么多的方法

 

 

 

你可能感兴趣的文章
加解密算法、消息摘要、消息认证技术、数字签名与公钥证书
查看>>
while()
查看>>
常用限制input的方法
查看>>
Ext Js简单事件处理和对象作用域
查看>>
IIS7下使用urlrewriter.dll配置
查看>>
12.通过微信小程序端访问企查查(采集工商信息)
查看>>
WinXp 开机登录密码
查看>>
POJ 1001 Exponentiation
查看>>
HDU 4377 Sub Sequence[串构造]
查看>>
云时代架构阅读笔记之四
查看>>
WEB请求处理一:浏览器请求发起处理
查看>>
Lua学习笔记(8): 元表
查看>>
PHP经典算法题
查看>>
LeetCode 404 Sum of Left Leaves
查看>>
醋泡大蒜有什么功效
查看>>
hdu 5115(2014北京—dp)
查看>>
数据结构中常见的树(BST二叉搜索树、AVL平衡二叉树、RBT红黑树、B-树、B+树、B*树)...
查看>>
PHP读取日志里数据方法理解
查看>>
第五十七篇、AVAssetReader和AVAssetWrite 对视频进行编码
查看>>
Vivado增量式编译
查看>>