JS中把函数作为另一函数的参数传递方法(总结)
今天在给元素注册事件的时候,使用addEventListener遇到了一个问题,这个好像之前也遇到过,觉得有必要总结一下,就是js函数作为参数引发的问题。首先看以下代码,觉得下面代码有问题吗?是否能达到点击id3对应的元素后,弹出id3呢?
例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); }; }
(资源库 www.zyku.net)
您可能感兴趣的文章
- 06-26highlightjs网页代码高亮插件调用方法
- 05-10JS - 获取文件后缀,判断文件类型(比如是否为图片格式)
- 05-10js中!和!!的区别与用法
- 05-10js实现文章目录索引导航(table of content)
- 05-10JS实现单张或多张图片持续无缝滚动的示例代码
- 05-10js根据后缀判断文件文件类型的代码
- 05-10JS端基于download.js实现图片、视频时直接下载而不是
- 04-02CentOS安装Nodejs教程
- 03-28VtigerCRM 7安装服务器参数配置教程
- 08-30织梦DedeCMS获取文章链接的函数GetOneArchive使用方法
- 03-07荣耀50se关闭应用自动管理教程
- 12-04微信边写边翻译功能使用教程分享
- 06-15HTML+CSS布局图标文字混排
- 01-11鹏祥云-鹏祥云应用软件功能介绍
- 01-11海马成长-海马成长应用软件功能介绍
- 09-17经纬度转详细地址几种方式
- 01-18萌哒哒娃娃机-萌哒哒娃娃机应用软件功
- 10-10华为nova9pro怎样开启低电量模式
- 01-19奇妙梦境-奇妙梦境应用软件功能介绍
- 01-12青苹果影院app-青苹果影院app应用软件
最近更新
阅读排行
猜你喜欢
- 05-10js中!和!!的区别与用法
- 12-26如何修改MYSQL默认用户名ROOT
- 12-29ZTISmart-ZTISmart应用软件功能介绍
- 09-25华为手表fitnew设置微信消息通知步骤
- 02-23DedeCMS内容页分页标签pagebreak的修
- 11-26procreate pocket吸色教程分享
- 10-08苹果13promax录屏功能在哪里
- 10-08一加8t怎么更改字体大小
- 04-26帝国CMS会员信息调用,会员空间信息调用
- 03-23小米手机分身添加至桌面步骤