JS怎么把元素ID作为变量js 函数传递id参数

1288人阅读
Javascript(25)
今天在给元素注册事件的时候,使用addEventListener遇到了一个问题,这个好像之前也遇到过,觉得有必要总结一下,就是JS函数作为参数引发的问题。首先看以下代码,觉得下面代码有问题吗?是否能达到点击id3对应的元素后,弹出id3呢?
var obj3=document.getElementById('id3');
obj3.addEventListener('click',curClick('id1'),true);
function curClick(id){
alert(id);
答案是否定,不能达到我想要的效果,因为这行代码在页面加载完成时候,就会弹出id3。当我单击id3对应的元素时候,页面没有任何反应。
于是我将代码改为如下两种情况:
var obj3=document.getElementById('id3');
obj3.addEventListener('click',function(e){curClick('id3');stopPropagation(e)},true);
function curClick(id){
alert(id);
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);
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:225281次
积分:4919
积分:4919
排名:第4226名
原创:253篇
转载:52篇
评论:91条
文章:20篇
阅读:7929
文章:14篇
阅读:13583
文章:16篇
阅读:15664
阅读:1811
文章:21篇
阅读:32869
文章:30篇
阅读:84095
(8)(12)(17)(5)(18)(51)(77)(55)(8)(19)(19)(13)(5)(1)

我要回帖

更多关于 js根据id获取元素 的文章

 

随机推荐