javascript事件委托是什么意思
时间:2021-10-29
来源:互联网
今天PHP爱好者为您带来在javascript中,事件委托也称为事件托管或事件代理,就是把目标节点的事件绑定到祖先节点上;它是利用事件冒泡原理,管理某一类型的所有事件,利用父元素来代表子元素的某一类型事件的处理方式。希望对大家有所帮助。
本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。
在 JavaScript 中,事件委托(delegate)也称为事件托管或事件代理,是利用事件冒泡原理,管理某一类型的所有事件,利用父元素来代表子元素的某一类型事件的处理方式。
这样做的好处:优化代码,提升运行性能,真正把 HTML 和 JavaScript 分离,也能防止出现在动态添加或删除节点过程中注册的事件丢失的现象。
示例1
下面示例使用一般方法为列表结构中每个列表项目绑定 click 事件,单击列表项目,将弹出提示对话框,提示当前节点包含的文本信息。但是,当我们为列表框动态添加列表项目之后,新添加的列表项目没有绑定 click 事件,这与我们的愿望相反。
<button id="btn">添加列表项目</button>
<ul id="list">
<li>列表项目1</li>
<li>列表项目2</li>
<li>列表项目3</li>
</ul>
<script>
var ul = document.getElementById("list");
var lis = ul.getElementsByTagName("li");
for (var i = 0; i < lis.length; i ++) {
lis[i].addEventListener('cluick', function (e) {
var e = e || window.event;
var target = e.target || e.srcElement;
alert(e.target.innerHTML);
}, false);
}
var i = 4;
var btn = document.getElementById("btn");
btn.addEventListener("click", function() {
var li = document.createElement("li");
li.innerHTML = "项目列表" + i++;
ul.appendChild(li);
});
</script>
示例2
下面示例借助事件委托技巧,利用事件传播机制,在列表框 ul 元素上绑定 click 事件,当事件传播到父节点 ul 上时,捕获 click 事件,然后在事件处理函数中检测当前事件响应节点类型,如果是 li 元素,则进一步执行下面代码,否则跳出事件处理函数,结束响应。
<button id="btn">添加项目列表</button>
<ul id="list">
<li>列表项目1</li>
<li>列表项目2</li>
<li>列表项目3</li>
</ul>
<script>
var ul = document.getElementById("list");
ul.addEventListener('click', function(e) {
var e = e || window.event;
var target = e.target || e.srcElement;
if (e.target && e.target.nodeName.toUpperCase()=="LI") {
alert(e.target.innerHTML);
}
}, false);
var i = 4;
var btn = document.getElementById("btn");
btn.addEventListener("click", function () {
var li = document.createElement("li");
li.innerHTML = "项目列表" + i++;
ul.appendChild(li);
});
</script>
当页面存在大量元素并且每个元素注册了一个或多个事件时,可能会影响性能。访问和修改更过的 DOM 节点时,程序就会更慢;特别是事件连接过程都发生在 load(或 DOMContentReady)事件中时,对任何一个富交互网页来说,这都是一个繁忙的时间段。另外,浏览器需要保存每个事件句柄的记录,也会占用更多内存。
以上就是javascript事件委托是什么意思的详细内容,更多请关注php爱好者其它相关文章!
-
七日世界检测点密码-检测点见闻任务密钥 时间:2025-05-14
-
二重螺旋致明日测试什么时候开始-测试开始时间 时间:2025-05-14
-
阴阳师逢魔演武怎么配队-逢魔演武阵容搭配玩法 时间:2025-05-14
-
币安如何购买USDT?-法币通道与P2P交易详细教程 时间:2025-05-14
-
崩坏星穹铁道3.4版本上半卡池怎么抽-3.4上半规划 时间:2025-05-14
-
燕云十六声凉州全新地图角色登场-张议潮将上线 时间:2025-05-14
今日更新
-
简析TP6框架的运行流程(附思维导图)
阅读:18
-
javascript的前身是什么
阅读:18
-
php如何判断方法和属性是否存在
阅读:18
-
Laravel Octane是什么?怎么用?
阅读:18
-
php怎么获取2个数组中不重复的值
阅读:18
-
composer扩展包上传的流程(推荐)
阅读:18
-
PHP中怎样绘制多边形、弧形和椭圆?(图文详解)
阅读:18
-
javascript三目运算符有几个等号
阅读:18
-
国内go get方式安装提示超时怎么办?(附解决办法)
阅读:18
-
遇到安装Xdebug后访问本地项目变得很慢怎么办?
阅读:18