JS中把函数作为另一函数的参数传递总结
2016-04-11 20:33
507 查看
今天在给元素注册事件的时候,使用addEventListener遇到了一个问题,这个好像之前也遇到过,觉得有必要总结一下,就是JS函数作为参数引发的问题。首先看以下代码,觉得下面代码有问题吗?是否能达到点击id3对应的元素后,弹出id3呢?
例1
答案是否定,不能达到我想要的效果,因为这行代码在页面加载完成时候,就会弹出id3。当我单击id3对应的元素时候,页面没有任何反应。
于是我将代码改为如下两种情况:
例2
例3
这次执行正常了,这是为什么呢?
因为在JS世界里curClick('id3')就是直接调用curClick('id3'),而非将其作为一个参数来传递,如果要将其作为一个参数来传递,如果不需要传递参数,直接传递函数名就可,如果需要传递参数,有两种解决办法
方法一:借助匿名函数,将要传递的函数,放在匿名函数中,将匿名函数作为参数如例2
eg:将function(){myfunction(val1,val2,......);}作为参数传递。
第二:改写需要传递函数
例1
var obj3=document.getElementById('id3'); obj3.addEventListener('click',curClick('id1'),true); function curClick(id){ alert(id); }
答案是否定,不能达到我想要的效果,因为这行代码在页面加载完成时候,就会弹出id3。当我单击id3对应的元素时候,页面没有任何反应。
于是我将代码改为如下两种情况:
例2
var obj3=document.getElementById('id3'); obj3.addEventListener('click',function(e){curClick('id3');stopPropagation(e)},true); function curClick(id){ alert(id); }
例3
var obj1=document.getElementById('id1'); obj1.addEventListener('click',curClick1,true); function curClick1(){ alert('okey'); }
这次执行正常了,这是为什么呢?
因为在JS世界里curClick('id3')就是直接调用curClick('id3'),而非将其作为一个参数来传递,如果要将其作为一个参数来传递,如果不需要传递参数,直接传递函数名就可,如果需要传递参数,有两种解决办法
方法一:借助匿名函数,将要传递的函数,放在匿名函数中,将匿名函数作为参数如例2
eg:将function(){myfunction(val1,val2,......);}作为参数传递。
第二:改写需要传递函数
function curClick1(val){ <span style="white-space:pre"> </span>return function(){ alert(val); }; }
相关文章推荐
- JavaScript 项目实战工具类
- JS 基础回顾(一)
- js练习题二:函数接收
- [BZOJ2257][Jsoi2009]瓶子和燃料
- 关于JS出现的Cannot read property 'XXX' of null错误
- qt+evaluatejavascript
- js和qt4 evaluteJavascript
- js练习题:网页换肤
- 获取前端post方式传过来的JSON格式的数据的代码
- js学习笔记3
- javaScript获取浏览器窗口可视区域大小
- JavaScript(1)
- js: how to get length of dict
- jsp中获取客户ip及其他资料的方法
- 【JS】:JS做的一个闹钟
- Jsp基础
- javascript学习笔记w3chool
- 【js】:js中对于两种控件不同的值得显示方法
- enum枚举定义转json
- 最近兰州的js风格写个插件和一个template engine