We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
对“事件处理程序过多”问题的解决访问就是事件委托。事件委托利用了事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件。
最近在做的一个专题就应用到了这个效果: 如上图所示,这里需要对多个li里的a标签,添加点击事件。如果对每一个a标签都添加事件侦听,无疑会对页面的性能造成很大的影响。这个时候咱们就回到文章的标题,可以利用事件委托来解决这个问题。 具体实现方案:给父级元素添加绑定事件,当事件发生时,判断事件的活动源是否是需要绑定的元素,如果是则执行相关方法。
$parent.on('click',function(event){ //给父元素添加click绑定事件 var $this = $(event.target) ; // 活动响应源 if($this.is($myTarget)) { // 事件发生,判断是否是确切要执行函数的绑定 foo();// 需执行的事件函数 } }
具体可查看 Demo ,或去我的github上扒取源码
The text was updated successfully, but these errors were encountered:
No branches or pull requests
最近在做的一个专题就应用到了这个效果:
如上图所示,这里需要对多个li里的a标签,添加点击事件。如果对每一个a标签都添加事件侦听,无疑会对页面的性能造成很大的影响。这个时候咱们就回到文章的标题,可以利用事件委托来解决这个问题。
具体实现方案:给父级元素添加绑定事件,当事件发生时,判断事件的活动源是否是需要绑定的元素,如果是则执行相关方法。
具体可查看 Demo ,或去我的github上扒取源码
希望这篇文章能对你有用,和我一起交流~
The text was updated successfully, but these errors were encountered: