浅析js的事件绑定&事件监听&事件委托的之间内容

本篇文章给大家带来的内容是关于浅析js的事件绑定&事件监听&事件委托的之间内容,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

1、事件绑定
要想让 javascript 对用户的操作作出响应,首先要对 dom 元素绑定事件处理函数。所谓事件处理函数,就是处理用户操作的函数,不同的操作对应不同的名称。
有三种常用的绑定事件的方法:
(1)在dom中直接绑定事件
我们可以在dom元素上绑定onclick、onmouseover、onmouseout、onmousedown、onmouseup、ondblclick、onkeydown、onkeypress、onkeyup等。

function hello(){    alert("hello world!");}

登录后复制

(2)在JavaScript代码中绑定事件
在JavaScript代码中(即 script 标签内)绑定事件可以使JavaScript代码与HTML标签分离,文档结构清晰,便于管理和开发。

document.getElementById("btn").onclick = function(){    alert("hello world!");}

登录后复制

(3)使用事件监听绑定事件
绑定事件的另一种方法是用 addEventListener() 或 attachEvent() 来绑定事件监听函数。
事件监听
关于事件监听,W3C规范中定义了3个事件阶段,依次是捕获阶段、目标阶段、冒泡阶段。
W3C规范

element.addEventListener(event, function, useCapture)

登录后复制

event : (必需)事件名,支持所有 DOM事件 。
function:(必需)指定要事件触发时执行的函数。
useCapture:(可选)指定事件是否在捕获或冒泡阶段执行。true,捕获。false,冒泡。默认false。

document.getElementById("btn1").addEventListener("click",hello);function hello(){    alert("hello world!");}

登录后复制

IE标准

element.attachEvent(event, function)

登录后复制

event:(必需)事件类型。需加“on“,例如:onclick。
function:(必需)指定要事件触发时执行的函数。

document.getElementById("btn2").attachEvent("onclick",hello);function hello(){    alert("hello world!");}

登录后复制

事件监听的优点
1、可以绑定多个事件。
常规的事件绑定只执行最后绑定的事件。而事件监听可以执行多个函数。

var btn4 = document.getElementById("btn4");btn4.addEventListener("click",hello1);btn4.addEventListener("click",hello2);function hello1(){    alert("hello 1");}function hello2(){    alert("hello 2");}

登录后复制

2、可以解除相应的绑定

var btn5 = document.getElementById("btn5");btn5.addEventListener("click",hello1);//执行了btn5.addEventListener("click",hello2);//不执行btn5.removeEventListener("click",hello2);function hello1(){    alert("hello 1");}function hello2(){    alert("hello 2");}

登录后复制

封装事件监听

//绑定监听事件function addEventHandler(target,type,fn){    if(target.addEventListener){        target.addEventListener(type,fn);    }else{        target.attachEvent("on"+type,fn);    }}//移除监听事件function removeEventHandler(target,type,fn){    if(target.removeEventListener){        target.removeEventListener(type,fn);    }else{        target.detachEvent("on"+type,fn);    }}

登录后复制

事件捕获:事件捕获指的是从document到触发事件的那个节点,即自上而下的去触发事件。
事件冒泡:是自下而上的去触发事件。绑定事件方法的第三个参数,就是控制事件触发顺序是否为事件捕获。true,事件捕获;false,事件冒泡。默认false,即事件冒泡。

  

document.getElementById("parent").addEventListener("click",function(e){                alert("parent事件被触发,"+this.id);            })            document.getElementById("child").addEventListener("click",function(e){                alert("child事件被触发,"+this.id)            })child事件被触发,childparent事件被触发,parent

登录后复制

结论:先child,然后parent。事件的触发顺序自内向外,这就是事件冒泡。
现在改变第三个参数的值为true:

document.getElementById("parent").addEventListener("click",function(e){                alert("parent事件被触发,"+e.target.id);            },true)            document.getElementById("child").addEventListener("click",function(e){                alert("child事件被触发,"+e.target.id)            },true)parent事件被触发,parentchild事件被触发,child

登录后复制

结论:先parent,然后child。事件触发顺序变更为自外向内,这就是事件捕获。

阻止事件冒泡,阻止默认事件
event.stopPropagation()方法:这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开。
event.preventDefault()方法:这是阻止默认事件的方法,调用此方法是,连接不会被打开,但是会发生冒泡,冒泡会传递到上一层的父元素
return false:这个方法比较暴力,他会同事阻止事件冒泡也会阻止默认事件;写上此代码,连接不会被打开,事件也不会传递到上一层的父元素;可以理解为return false就等于同时调用了event.stopPropagation()和event.preventDefault()

2.事件委托
事件委托就是利用冒泡的原理,把事件加到父元素或祖先元素上,触发执行效果。

var btn6 = document.getElementById("btn6");document.onclick = function(event){    event = event || window.event;    var target = event.target || event.srcElement;    if(target == btn6){        alert(btn5.value);    }}

登录后复制

事件委托优点
1、提高JavaScript性能。事件委托可以显著的提高事件的处理速度,减少内存的占用


登录后复制登录后复制  item1  item2  item3 var item1 = document.getElementById(“item1”); var item2 = document.getElementById(“item2”); var item3 = document.getElementById(“item3”);document.addEventListener(“click”,function(event){ var target = event.target; if(target == item1){ alert(“hello item1”); }else if(target == item2){ alert(“hello item2”); }else if(target == item3){ alert(“hello item3”); }})

2、动态的添加DOM元素,不需要因为元素的改动而修改事件绑定。


登录后复制登录后复制  item1  item2  item3var list = document.getElementById(“list”);document.addEventListener(“click”,function(event){ var target = event.target; if(target.nodeName == “LI”){ alert(target.innerHTML); }})var node=document.createElement(“li”);var textnode=document.createTextNode(“item4”);node.appendChild(textnode);list.appendChild(node);

  相关推荐:

浅谈jquery之on()绑定事件和off()解除绑定事件

浅谈JavaScript事件绑定的常用方法及其优缺点分析

以上就是浅析js的事件绑定&事件监听&事件委托的之间内容的详细内容,更多请关注【创想鸟】其它相关文章!

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

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

(0)
上一篇 2025年3月8日 02:55:36
下一篇 2025年3月8日 02:55:45

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

相关推荐

  • js事件委托是什么?使用js事件委托的好处有哪些?

    js事件委托是什么?使用事件委托又有哪些好处?相信很多的朋友或许会有这样的疑问,那么,接下来的这篇文章就给大家来说一说关于js事件委托的概念以及使用js事件委托的好处。 1、什么是js事件委托? 利用事件冒泡处理动态元素事件绑定的方法,专业…

    编程技术 2025年3月8日
    200
  • JavaScript事件委托的详细介绍(附代码)

    本篇文章给大家带来的内容是关于javascript事件委托的详细介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 事件委托(又名事件代理),就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件…

    编程技术 2025年3月8日
    200
  • jquery绑定事件有几种方式?

    jquery绑定事件有4种方式,分别为:bind()、live()、delegate()和on()方法;其中bind()方法只能针对已经存在的元素进行事件的绑定,而live()、on()、delegate()均支持未来新添加元素的事件绑定。…

    2025年3月7日
    200
  • 了解nodejs中的事件和事件循环

    相关推荐:《nodejs 教程》 熟悉javascript的朋友应该都使用过事件,比如鼠标的移动,鼠标的点击,键盘的输入等等。我们在javascript中监听这些事件,从而触发相应的处理。 同样的nodejs中也有事件,并且还有一个专门的e…

    2025年3月7日
    200
  • 深入浅析JS中的事件委托

    为什么要进行事件委托? 首先实现一个小功能:在单击 HTML 的按钮后,把消息输出到控制台。 为了实现这个小功能,你需要选择按钮,然后再用 addEventListener() 方法来附加事件监听器: Click me document.g…

    2025年3月7日
    200
  • 浅谈JavaScript中的事件委托

    本篇文章给大家介绍一下javascript中的事件委托。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 事件委托 利用事件冒泡,指定一个事件处理程序,管理一系列的所有事件事件委托利用DOM元素的事件冒泡,把子元素的相关事件…

    2025年3月7日 编程技术
    200
  • javascript如何解除事件绑定

    方法:1、直接删除法,使用“对象.onclick=false;”语句删除绑定事件即可。2、先使用addEventListener绑定事件,再使用removeEventListener删除绑定事件即可。 本教程操作环境:windows7系统、…

    2025年3月7日
    200
  • javascript绑定事件的方法有哪些

    绑定方法:1、直接在标签中使用“onclick”属性绑定事件;2、使用“对象.onclick=function(){事件}”语句绑定事件;3、使用“对象.attachEvent(‘click’,function(){…

    2025年3月7日
    200
  • javascript事件绑定的方法有哪些

    绑定方法:1、使用“对象.on事件名 = function(){代码}”语句绑定;2、使用“事件源.addEventListener(事件名称,事件处理函数名,是否捕获);”语句绑定;3、在HTML标签中使用“onclick”属性绑定事件。…

    2025年3月7日
    200
  • javascript怎么设置事件监听

    设置方法:1、在HTML的标签中通过事件属性进行设置,语法“on+事件名=”处理函数””;2、使用“element.onclick”进行设置;3、使用addEventListener()方法进行设置。 本教程操作环境…

    2025年3月7日
    200

发表回复

登录后才能评论