JS中把函数作为另一函数的参数传递方法(总结)
作者:jingxian 时间:2024-05-05 09:14:39
今天在给元素注册事件的时候,使用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);
};
}
标签:函数,参数,传递
0
投稿
猜你喜欢
SQLServer行转列实现思路记录
2024-01-18 05:42:43
ASP中实现分页显示的七种方法
2007-09-20 13:19:00
如何通过命令行进入python
2022-10-28 22:12:56
YUI Compressor 组件压缩 JavaScript 的一些原理
2009-08-02 20:22:00
python调用windows api锁定计算机示例
2021-09-08 03:28:38
基于python实现聊天室程序
2022-09-26 07:50:33
兼容主流浏览器,纯CSS下拉菜单
2010-09-05 20:30:00
在Ubuntu使用SQL Server创建Go应用程序的图文教程
2024-01-15 10:50:50
一次MySQL慢查询导致的故障
2024-01-21 12:18:17
MySQL索引概念及七种索引类型分享介绍
2024-01-23 03:55:27
python GUI库图形界面开发之PyQt5窗口类QMainWindow详细使用方法
2021-03-16 08:53:47
Js nodeType 属性全面解析
2024-04-16 09:53:30
Python爬取网易云音乐热门评论
2022-06-16 00:24:58
戏说编码发展史
2022-12-12 02:48:05
python3使用mutagen进行音频元数据处理的方法
2023-05-25 04:05:32
在Win2003 64位下ASP无法连接Access数据库
2011-03-30 11:22:00
python将xml xsl文件生成html文件存储示例讲解
2023-08-11 20:36:41
使用Title提升可访问性
2009-04-04 17:06:00
Python实现邮件自动下载的示例详解
2023-06-15 04:44:35
MySQL的添加用户的两种方法
2012-01-29 17:50:10