设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 数据 创业者
当前位置: 首页 > 综合聚焦 > 编程要点 > 正文

js事件委托机制你知道多少?浅谈js事件委托和深浅拷贝

发布时间:2022-02-18 11:04 所属栏目:13 来源:互联网
导读:这篇文章给大家分享的是有关js事件委托机制以及深浅拷贝,很多新手对于这两个内容不是很清楚,因此分享给大家做个参考,下面就跟随小编一起来学习看看吧。 一、事件委托 首先呢,介绍一下事件绑定 //方法一:通过onclick button onclick=clickEvent()点击/bu
      这篇文章给大家分享的是有关js事件委托机制以及深浅拷贝,很多新手对于这两个内容不是很清楚,因此分享给大家做个参考,下面就跟随小编一起来学习看看吧。
 
       一、事件委托
       首先呢,介绍一下事件绑定
 
//方法一:通过onclick
<button onclick="clickEvent()">点击</button>
 
<script>
function clickEvent(){
   alert("点击事件");
}
</script>
 
//方法二:通过addEventListener
<button id="btn_button">点击</button>
 
<script>
var btn = document.getElementById("btn_button");
btn.addEventListener("click", function () {
  alert("点击");
}, false);
</script>
       说下其中的区别
       onclick只能绑定一个事件,而addEventListener可以同时绑定多个事件
 
[function method1() {
  console.log("method1");
}
function method2() {
  console.log("method2");
}
function method3() {
  console.log("method3");
}
var btn = document.getElementById("btn_button");
btn.addEventListener("click", method1, false);//第三个参数是默认值,默认是冒泡,如果设置为true则是捕获
btn.addEventListener("click", method2, false);
btn.addEventListener("click", method3, false);
//最终会按顺序执行:method1 -> method2 -> method3
btn.removeEventListener("click", method1, false);//用于移除事件
 
 
btn.onclick = method1;
btn.onclick = method2;
btn.onclick = method3;
//最终只会执行method3
btn.onclick = null;//用于移除事件
       事件冒泡
<ul id="container" style="display: inline-block;">
  <li id="title1">123456</li>
  <li id="title2">qwert</li>
  <li id="title3">
    <ul>
      <li id="title3inner">title3里面的文本</li>
    </ul>
  </li>
</ul>
 
<script>
  var container = document.getElementById("container");
  var title1 = document.getElementById("title1");
  var title2 = document.getElementById("title2");
  var title3 = document.getElementById("title3");
  var title3inner = document.getElementById("title3inner");
 
  container.onclick = function (e) {
    alert("container");
  }
  title1.onclick = function (e) {
    alert("title1");
  }
  title2.onclick = function (e) {
    alert("title2");
  }
  title3.onclick = function (e) {
    alert("title3");
  }
  title3inner.onclick = function (e) {
    alert("title3inner");
  }
</script>
       点击 “title3里面的文本” 会触发 3 次事件,分别 弹出“title3inner” -> “title3” -> “container”
 
       事件捕获
       至于事件冒泡倒过来即是事件捕获,即:点击 “title3里面的文本” 会触发 3 次事件,分别 弹出“container” -> “title3” -> “title3inner”
 
       事件冒泡的升华
       事件委托的使用
 
<ul id="container" style="display: inline-block;">
  <li id="title1">123456</li>
  <li id="title2">qwert</li>
  <li id="title3">QWE123</li>
</ul>
 
<script>
var container = document.getElementById("container");
container.onclick = function (e) {
  //console.log(e);
  if (e.target.id = "title1") {
    alert(e.target.innerText);
  }
  else if (e.target.id = "title2") {
    alert(e.target.innerText);
  }
  else if (e.target.id = "title3") {
    alert(e.target.innerText);
  }
}
</script>
       至于优势嘛,便是只需注册一个点击事件,然后通过target来判断点击的具体元素。而currentTarget指的是注册事件的元素。target是你实际中点击的元素,currentTarget是绑定事件的元素。如果不用事件委托的话,在一个列表上,每条数据后,添加一个按钮,然后给每个按钮注册一个事件,每个元素绑定一个事件,那么多的按钮,肯定会对前端性能有所影响。这时候委托肯定是最好的选择了,毕竟委托只需注册一个事件。
 
       二、深浅拷贝
       至于深浅拷贝这块的知识,我便长话短说了,一阵见血,见血封喉!
 
let a = 3;
let b = a;
a = 4;
console.log(a);//4
console.log(b);//3
console.log(a === b);//这便是深拷贝,a和b完全是不同的变量,各自保存一个值。
 
 
let arr = [1, 2, 3, 4, 5];
let brr = JSON.parse(JSON.stringify(arr));
arr[1] = 8;
console.log(brr[1]);//2,这便实现了所谓的深拷贝
       以上就是关于js事件委托机制以及深浅拷贝的介绍,上述一些知识可能实际使用价值不是很大,但是对于学习来说,了解还是有必要的,希望文本对大家学习有帮助,想要了解更多js事件委托的内容大家可以继续关注其他文章。

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读