您现在的位置是:群英 > 开发技术 > web开发
详解js中的事件对象、事件源对象和事件流分别都是什么?
Admin发表于 2022-08-31 17:26:30469 次浏览
这篇文章主要给大家介绍“详解js中的事件对象、事件源对象和事件流分别都是什么?”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“详解js中的事件对象、事件源对象和事件流分别都是什么?”文章能对大家有所帮助。

js中事件对象、事件源对象、事件流分析理解

事件对象(event)

  • 什么是事件:事件就是指js中所有可以发生的有并且有监听的事件,比如:(鼠标、键盘以及浏览器窗口变化等)

  • 是什么是事件对象(event):通俗讲就是一个记录了事件各种信息的一个对象。
    这里需要注意的是:事件对象会有兼容性问题,在除IE的浏览器中为event,而非浏览器中为window.event,

btn.onclick = function(event){let e = event || window.event}

事件源对象

简单来说,就是指事件具体是在那个对象上发生的,对于element元素来说,事件源对象就是指你所点击的元素。同样存在浏览器兼容问题:

  • 在fireFox中为event.srcElement
  • 在IE中为event.target
    兼容写法参照事件对象

事件流

事件流主要分为两类:1.捕获事件 2.冒泡事件 触发顺序是先捕获在冒泡
但是如果细分的话在捕获到冒泡阶段会存在一个目标阶段,即所具体操做的dom元素要进行的操作阶段

捕获事件

先由最上一级的节点先接收事件,然后向下传播到具体的节点。eg:当用户点击了p元素,采用事件捕获,则click事件将按照document>htm>body>p的顺序进行传播。传递方式是由外向内传递。

冒泡事件

和捕获事件相反,它是由内向外传递,当用户点击p时它会向父级传递,p>body>html。***由于这种特性常常用于事件委托。

事件委托

我们将所有子元素要触发的相同事件绑定到父元素身上,这样可以减少对DOM操作提高性能。具体使用方法是使用事件源对象的方法。

<ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
    </ul>

要对li绑定点击事件,通常我们的做法是循环给li田间点击事件

 let oLi = document.querySelectorAll("li")
 for(let i; i < oLi.length; i++){
            oLi[i].onclick = function(){
                console.log("i")
            }
        }

而使用事件委托的方法是

let oUl = document.querySelector("ul")
  oUl.onclick = function(event){
            let e = event || window.event
            console.log(e.target.innerHTML)
        }
  • 优点
  • 提高性能,不需要循环所有元素一个一个绑定事件。
  • 灵活,有动态创建进来的新元素不需要重新绑定事件。

阻止事件冒泡和阻止默认事件

阻止事件冒泡的操作(兼容性写法)

***有些事件不需要进行冒泡操作

function stopBubble(event){
    var e = event||window.event //事件对象兼容写法
    e.stopProgation() ? e.stopProgation() : e.cancelBubble = true //IE兼容写法}

阻止默认事件(兼容写法)

***阻止a标签以及鼠标右键默认跳转和菜单事件

function cancelHandle(event){
    var e = event||window.event
    e.preventDefault() ? e.preventDefault() : e.returnValue = false/*ie*/}



通过以上内容的阐述,相信大家对“详解js中的事件对象、事件源对象和事件流分别都是什么?”已经有了进一步的了解,更多相关的问题,欢迎关注群英网络或到群英官网咨询客服。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: JavaScript
相关信息推荐
2022-08-24 16:47:16 
摘要:在 PHP 里所有的闭包都是 Clourse 类所实例化的一个对象,也就是说闭包与其他 PHP 对象没有什么不同。而一个对象就必然有其方法和属性,这篇文章将总结 PHP 中闭包的基础用法和 Clourse 类方法的作用。
2022-05-12 11:25:14 
摘要:这篇文章主要介绍了php下的原生ajax请求用法,结合实例形式分析了前台原生ajax请求与后台PHP响应相关操作技巧,需要的朋友可以参考下
2022-08-31 17:53:54 
摘要:在HTML5中,nav标签是导航标签;nav的全称是navigation,意为导航,该标签定义导航链接的部分,用于表示HTML页面中的导航,该标签并不是所有的HTML文档都要使用,只是作为标注一个导航链接的区域。
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部