JS事件委托和事件分派
JS事件委托
定义:若需要对子元素进行统一的监听管理,可以将其委托给它们共同的父元素,通过event对象对指定子元素进行筛选和操作。
<body>
<ul class="wrap">
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
<script>
let oWrap = document.querySelector(".wrap")
oWrap.addEventListener("click", function (e) {
if (e.target.tagName.toLowerCase() === "li") {
console.log(e.target.innerText);
}
},false)
</script>
</body>
当点击每个li时,获取文本内容
data:image/s3,"s3://crabby-images/09fd4/09fd4978dbd4b11e6d0d3571321bac44a271a018" alt="请添加图片描述" data:image/s3,"s3://crabby-images/5192f/5192fdc3383c9afb16e0d42e4b82d74b33671dea" alt="请添加图片描述"
JS事件分派
定义:对于同一组或一类相关联事件,可以对其中各部分回调函数进行统一分派映射管理
<body>
<div class="wrap">1</div>
<script>
let oWrap = document.querySelector(".wrap")
let assignObj = {
mousedown: function (e) {
console.log("我是mousedown");
},
mousemove: function (e) {
console.log("我是mousemove");
},
mouseup: function (e) {
console.log("我是mouseup");
},
}
oWrap.addEventListener("mousedown", assignTask, false)
oWrap.addEventListener("mousemove", assignTask, false)
oWrap.addEventListener("mouseup", assignTask, false)
function assignTask(e) {
if (assignObj[e.type] && typeof assignObj[e.type] === "function") {
assignObj[e.type]()
}
}
</script>
</body>
成功触发分派事件
data:image/s3,"s3://crabby-images/2bc24/2bc249299d67564c68b5361859b0703fb0077032" alt="请添加图片描述" data:image/s3,"s3://crabby-images/9abc0/9abc041177d887c2fe9d73e561fa4ed5f93a9814" alt="请添加图片描述"
|