时间:2021-05-18
今天聊下JavaScript中的事件委托跟深浅拷贝
首先呢,介绍一下事件绑定
//方法一:通过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可以同时绑定多个事件
点击 “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是绑定事件的元素
如果不用事件委托的话,在一个列表上,每条数据后,添加一个按钮,然后给每个按钮注册一个事件,每个元素绑定一个事件,那么多的按钮,肯定会对前端性能有所影响。这时候委托肯定是最好的选择了,毕竟委托只需注册一个事件。
理论上,使用事件委托确实是一种优化,只需注册一个事件,然后通过事件冒泡来实现相应的功能。
至于在Vue项目中,到底用不用事件委托呢?这里好像有个争议。
有人说在Vue中,已经帮你做过了,也有人说并没有,我没看过源码,咱也不知道。
总之,我是这么做的,每个按钮都绑定一个事件,然后阻止冒泡。实际中,我个人不太会考虑事件委托,感觉不是太必要的,毕竟事件并没有那么多。
至于深浅拷贝这块的知识,我便长话短说了,一阵见血,见血封喉!
let a = 3;let b = a;a = 4;console.log(a);//4console.log(b);//3console.log(a === b);//这便是深拷贝,a和b完全是不同的变量,各自保存一个值。let arr = [1, 2, 3, 4, 5];let brr = arr;arr[1] = 8;console.log(arr[1]);//8console.log(brr[1]);//8 为什么呢? 这便是浅拷贝,数组类型是引用类型,arr跟brr变量只是保存的引用地址,他们共同指向[1,2,3,4,5]这个数组console.log(arr === brr);//true实际中,如果要实现深拷贝,怎么做呢?
方法主要是一个通过递归来赋值,还有一个通过JSON.stringify与JSON.parse这两个方法来实现。
在这里使用第二种方法,毕竟最是简单,简单、暴力,也往往是最有效的解决办法。
正如面试官的所说,虽然以上的知识在实际工作中并不一定会用到,但你还是要知道的!还是要知道!!还是要知道的!!!
到此这篇关于浅析JavaScript中的事件委托机制跟深浅拷贝的文章就介绍到这了,更多相关js事件委托深浅拷贝内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS中的事件委托。分享给大家供大家参考,具体如下:事件委托(也叫事件代理),其实这个问题也简单,要想弄明白事件委托,我们先要把事件冒泡的机制搞清楚
前言深浅拷贝知识在我们的日常开发中还算是用的比较多,但是之前的状态一直都是只曾听闻,未曾使用(其实用了只是自己没有意识到),所以今天来跟大家聊一聊js的深浅拷贝
基于浏览器的事件轮询机制(以及Node.js中的事件轮询机制),JavaScript常常会运行在异步环境中。由于JavaScript本身语言的特性(不需要程序员
本节内容深浅拷贝循环方式字典常用方法总结一、深浅拷贝列表、元组、字典(以及其他)对于列表、元组和字典而言,进行赋值(=)、浅拷贝(copy)、深拷贝(deepc
本文实例讲述了javascript二维数组和对象的深拷贝与浅拷贝。分享给大家供大家参考,具体如下:这篇文章主要为大家详细介绍了js实现数组和对象的深浅拷贝,1.