一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - 淺析JavaScript中的事件委托機制跟深淺拷貝

淺析JavaScript中的事件委托機制跟深淺拷貝

2022-01-05 16:46打游戲也要有夢想 js教程

這篇文章主要介紹了JavaScript中的事件委托機制跟深淺拷貝,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

今天聊下JavaScript中的事件委托跟深淺拷貝

一、事件委托

首先呢,介紹一下事件綁定

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//方法一:通過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可以同時綁定多個事件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
[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;//用于移除事件

事件冒泡

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<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”

事件冒泡的升華

事件委托的使用

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<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中,已經幫你做過了,也有人說并沒有,我沒看過源碼,咱也不知道。

淺析JavaScript中的事件委托機制跟深淺拷貝

總之,我是這么做的,每個按鈕都綁定一個事件,然后阻止冒泡。實際中,我個人不太會考慮事件委托,感覺不是太必要的,畢竟事件并沒有那么多。

二、深淺拷貝

至于深淺拷貝這塊的知識,我便長話短說了,一陣見血,見血封喉!

淺析JavaScript中的事件委托機制跟深淺拷貝

?
1
2
3
4
5
6
7
8
9
10
11
12
13
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 = arr;
arr[1] = 8;
console.log(arr[1]);//8
console.log(brr[1]);//8  為什么呢? 這便是淺拷貝,數組類型是引用類型,arr跟brr變量只是保存的引用地址,他們共同指向[1,2,3,4,5]這個數組
console.log(arr === brr);//true

實際中,如果要實現深拷貝,怎么做呢?
方法主要是一個通過遞歸來賦值,還有一個通過JSON.stringify與JSON.parse這兩個方法來實現。
在這里使用第二種方法,畢竟最是簡單,簡單、暴力,也往往是最有效的解決辦法。

?
1
2
3
4
let arr = [1, 2, 3, 4, 5];
let brr = JSON.parse(JSON.stringify(arr));
arr[1] = 8;
console.log(brr[1]);//2,這便實現了所謂的深拷貝

三、總結

正如面試官的所說,雖然以上的知識在實際工作中并不一定會用到,但你還是要知道的!還是要知道!!還是要知道的?。。?/p>

到此這篇關于淺析JavaScript中的事件委托機制跟深淺拷貝的文章就介紹到這了,更多相關js事件委托深淺拷貝內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/ywjbokeyuan/p/14290030.html

延伸 · 閱讀

精彩推薦
  • js教程淺析JavaScript中的事件委托機制跟深淺拷貝

    淺析JavaScript中的事件委托機制跟深淺拷貝

    這篇文章主要介紹了JavaScript中的事件委托機制跟深淺拷貝,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要...

    打游戲也要有夢想5552022-01-05
  • js教程js數組的基本使用總結

    js數組的基本使用總結

    這篇文章主要給大家介紹了關于js數組的基本使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    抓泥鰍5312022-01-04
  • js教程微信小程序實現簡單購物車功能

    微信小程序實現簡單購物車功能

    這篇文章主要為大家詳細介紹了微信小程序實現簡單購物車功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    mossbaoo5132021-12-22
  • js教程詳解uniapp的全局變量實現方式

    詳解uniapp的全局變量實現方式

    這篇文章主要介紹了詳解uniapp的全局變量實現方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    繭君10792021-12-29
  • js教程Javascript實現漢字和拼音互轉的終極方案

    Javascript實現漢字和拼音互轉的終極方案

    網上關于JS實現漢字和拼音互轉的文章很多,但是比較雜亂,有的不支持多音字、不支持聲調或者字典文件太大,無法根據實際需要滿足需求。這篇文章給...

    我是小茗同學10162021-12-15
  • js教程JavaScript 防盜鏈的原理以及破解方法

    JavaScript 防盜鏈的原理以及破解方法

    這篇文章主要介紹了JavaScript 防盜鏈的原理以及破解方法,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下...

    LuckyChou10302021-12-22
  • js教程javascript實現隨機抽獎功能

    javascript實現隨機抽獎功能

    這篇文章主要為大家詳細介紹了javascript實現隨機抽獎功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    彴兗7012021-12-23
  • js教程js實現有趣的倒計時效果

    js實現有趣的倒計時效果

    這篇文章主要為大家詳細介紹了js實現有趣的倒計時效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    搬磚大法4242022-01-04
主站蜘蛛池模板: 日本中文字幕黑人借宿影片 | 艾秋麻豆果冻剧传媒在线播放 | 日韩免费毛片视频杨思敏 | 九九99在线视频 | 午夜精品久久久久久久99 | 天天操婷婷 | 国产亚洲一级精品久久 | 亚洲 欧美 清纯 校园 另类 | 91免费永久在线地址 | 国内精品久久久久久久久 | 久久精品免视看国产 | 国产播放啪视频免费视频 | 精品一区二区三区在线成人 | 桃色综合网 | 久久伊人影院 | 国产精品露脸国语对白99 | 亚洲 日本 天堂 国产 在线 | 久久精品中文字幕 | 好男人影视社区www在线观看 | 五月性| 白丝超短裙被输出娇喘不停小说 | 九九成人免费视频 | 欧美久草在线 | 催眠白丝舞蹈老师小说 | 午夜精品区 | 全肉一女n男np高h双龙养成 | 精品小视频在线观看 | 亚洲精品国产福利片 | 国内精品视频一区二区三区 | 日本一道本视频 | 无码专区aaaaaa免费视频 | 草逼视频网址 | 好妈妈7在线观看高清 | 亚洲看片lutube在线入口 | 波多野结中文字幕在线69视频 | 亚洲精品国产国语 | 91在线精品老司机免费播放 | 日韩欧美a | 亚洲国产精品网 | 亚洲AV无码国产精品午夜久久 | 三级午夜宅宅伦不卡在线 |