javascript事件委托的代码实现以及代码的优化

本篇文章给大家带来的内容是关于js事件委托的代码实现以及代码的优化,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

前两天接手了同事的一个项目,是一个网站首页,其中有段代码很累赘,要实现的功能就是,

通过给父元素添加鼠标移入移出事件,来控制子元素显示隐藏。

html代码,一共有四个父元素div,每个父元素嵌套一个子元素div,

这是截取了其中一个div:

立即学习“Java免费学习笔记(深入)”;

javascript事件委托的代码实现以及代码的优化

最简单粗暴的方法莫过于这样:

javascript事件委托的代码实现以及代码的优化

直接写八个方法,分别设置属性的样式block或者none。

这样写虽然简单,但是出于代码优化,页面响应速度的关系,我们还是需要改动的。

问了问同事,说看看有关事件委托的相关方法,能有效解决这个问题。

经过一顿操作之后,楼主写出了如下代码:

javascript事件委托的代码实现以及代码的优化

这么写能实现效果了,可是在查看控制台的时候竟然一片飘红。

javascript事件委托的代码实现以及代码的优化

实在是头痛啊,看到这个。明明效果实现了,为什么还报错呢?

今天中午午休的时候,趴着想了想,突然就来了灵感。

javascript事件委托的代码实现以及代码的优化

这是修改之后的代码。看完你就明白,这是因为target指代的是当前对象,

当鼠标移到父元素div时,子元素p属性变为block,会显示出来。

但是当你移动到子元素div上时,target就指向了子元素,而子元素没有firstElementChild,所以会报错。

这时我们只需加个判断,如果子对象不存在,那么就修改当前对象的属性。

否则,也就是子对象存在的情况,那就修改子对象属性。

经过了两天的折腾,终于优化了这么一小段代码。

本来是想到的for循环,但是这样循环下来,dom操作还是很多。

相关推荐:

js如何获取音频和视频采集的资源?js采集音频和视频的方法

js运算符优先级的比较及js逻辑运算符的解析

js事件里面的this什么意思?详解js中this的用法(附使用例子)

以上就是javascript事件委托的代码实现以及代码的优化的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2744147.html

(0)
上一篇 2025年3月8日 03:15:52
下一篇 2025年2月24日 18:19:39

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js事件委托是什么?javascript事件委托的介绍

    本篇文章给大家带来的内容是关于什么是js事件委托?js事件委托的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 什么是js事件委托呢?他又有什么好处?说白了js事件委托就是利用冒泡的原理,把本应该添加到某个元素上的事件…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论