基于函数执行的踩坑(addEventListener)
更新时间:2023年01月21日 09:05:37 作者:烯烃@
这篇文章主要介绍了基于函数执行的踩坑(addEventListener),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
记录一次踩坑经历
写法一
const outer = function () { var x = "我是外面函数的变量"; console.log('我现在要在外层被调用'); return function () { console.log(x); } }; document.addEventListener('scroll', outer)
结果:
写法二
const outer = function () { var x = "我是外面函数的变量"; console.log('我现在要在外层被调用'); return function () { console.log(x); } }; document.addEventListener('scroll', outer())
结果:
两种写法在于第二种写法在事件绑定的时候默认的执行了一次outer,所以得到的是inner函数了,以后翻页执行的是inner函数
.addEventListener添加事件失败原因之一
正确语法
document.getElementById("myBtn").addEventListener("click", function(){ document.getElementById("demo").innerHTML = "Hello World"; });
addEventListener() 方法用于向指定元素添加事件句柄。
注意,这个指定元素是一个元素,所以当使用document.getElementsByClassName();来获取对象然后再添加事件的时候就会失效,因为它获取的是一个数组对象。
错误语法
document.getElementsByClassName("myBtn").addEventListener("click", function(){ document.getElementById("demo").innerHTML = "Hello World"; });
当然,对应数组对象,要访问其中的一个元素,我们要加上数字角标。
使用方式为:
var x = document.getElementsByClassName(); x[0].innerHTML = 'nihao';
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
屏蔽鼠标右键、Ctrl+N、Shift+F10、Alt+F4、F11、F5刷新、退格键
js 防止刷新网页、禁止后退,右键等操作的代码2010-03-03检查输入的是否是数字使用keyCode配合onkeypress事件
检查输入的是否是数字在本文使用keyCode配合onkeypress事件来实现,具体示例如下2014-01-01JavaScript中关键字 var、let、const的区别详解
在JavaScript中,var、let和const是用于声明变量的关键字,它们之间存在一些区别,这篇文章就给大家详细介绍一下它们之间的区别,文章通过代码示例介绍的非常详细,需要的朋友可以参考下2023-08-08
最新评论