成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript疑難雜癥系列-事件

Anleb / 2264人閱讀

摘要:支持三個(gè)參數(shù)分別表示事件名稱,是否可以冒泡,是否阻止事件的默認(rèn)操作觸發(fā)參數(shù)表示事件對(duì)象,是方法返回的創(chuàng)建的對(duì)象監(jiān)聽方法自定義事件常用模擬模擬方法操作或者自定義事件我的自定義事件。

事件這塊知識(shí)點(diǎn)雖然是老生長(zhǎng)談的,但對(duì)于我來說多多整理,多多感悟,溫故知新,每次看看這塊都有不同的收獲.(在這里我不會(huì)長(zhǎng)篇大論,只會(huì)挑重點(diǎn);具體的小伙伴們自行查找)
什么是事件
在編程時(shí)系統(tǒng)內(nèi)發(fā)生的動(dòng)作或者發(fā)生的事情.
系統(tǒng)通過它來告訴編程者,在編程者愿意的情況下,編程者一某種方式對(duì)它做出回應(yīng).
添加事件方式 元素屬性
var btn = document.querySelector("button");

btn.onclick = function() {
  var rndCol = "rgb(" + random(255) + "," + random(255) + "," + random(255) + ")";
  document.body.style.backgroundColor = rndCol;
}

或者

var btn = document.querySelector("button");

function bgChange() {
  var rndCol = "rgb(" + random(255) + "," + random(255) + "," + random(255) + ")";
  document.body.style.backgroundColor = rndCol;
}

btn.onclick = bgChange
行內(nèi)事件


function bgChange() {
  var rndCol = "rgb(" + random(255) + "," + random(255) + "," + random(255) + ")";
  document.body.style.backgroundColor = rndCol;
}

或者

注冊(cè)事件監(jiān)聽
addEventListener()和removeEventListener();

btn.addEventListener("click", function() {
  var rndCol = "rgb(" + random(255) + "," + random(255) + "," + random(255) + ")";
  document.body.style.backgroundColor = rndCol;
});

或者

btn.removeEventListener("click", bgChange);
優(yōu)缺點(diǎn)

元素屬性

優(yōu):
     1. 兼容性好
     2. 行為的分離
     3.便于操作當(dāng)事對(duì)象,因?yàn)閒unction是作為on***的屬性出現(xiàn)的,可直接用this引用當(dāng)事對(duì)象
缺: 
     1. 給同一個(gè)監(jiān)聽器注冊(cè)多個(gè)處理器,后面的會(huì)覆蓋前面
     btn.onclick=function(){alert("a")};
     btn.onclick=function(){alert("b")};

行內(nèi)事件

優(yōu):
     1. 兼容性好,是最早的事件處理方法
     2. 方便快捷
缺: 
     1. 代碼雜糅
     2. 難以管理和效率低下,一個(gè)按鈕看起來還好,但是如果有一百個(gè)按鈕呢?得在文件中加上100個(gè)屬性
     3. 文檔很難解析

注冊(cè)事件監(jiān)聽

優(yōu):
     1. 它允許為事件添加多個(gè)多帶帶的處理程序。這對(duì)于DHTML庫(kù)或Mozilla擴(kuò)展尤其有用,即使使用其他庫(kù)/擴(kuò)展也需要很好的工作
     2. 它可以讓你更好地控制階段,當(dāng)聽者被激活(捕獲與冒泡)
     3. 它適用于任何DOM元素,而不僅僅是HTML元素
     4. 行為的分離 
缺:
    兼容性(不過網(wǎng)上有很多成熟的hack);
事件對(duì)象

具體請(qǐng)看event詳解-https://developer.mozilla.org

在觸發(fā)DOM上的某個(gè)事件時(shí),會(huì)在事件處理程序函數(shù)中會(huì)產(chǎn)生一個(gè)事件對(duì)象event,這個(gè)對(duì)象中包含著所有與事件有關(guān)的信息。包括導(dǎo)致事件的元素、事件的類型以及其他與特定事件相關(guān)的信息.

var btn = document.getElementById("myBtn");
btn.onclick = function(event) {
    alert(event.type); //"click"
}
btn.addEventListener("click", function(event) {
    alert(event.type); //"click"
}, false);
event.currentTarget與event.target
事件對(duì)象event的target屬性始終是事件剛剛發(fā)生的元素的引用

例如,你可能有一組16塊方格,當(dāng)它們被點(diǎn)擊時(shí)就會(huì)消失。用e.target總是能準(zhǔn)確選擇當(dāng)前操作的東西(方格)并執(zhí)行操作讓它消失,而不是必須以更困難的方式選擇它.

var divs = document.querySelectorAll("div");

for (var i = 0; i < divs.length; i++) {
  divs[i].onclick = function(e) {
    e.target.style.backgroundColor = bgChange();
  }
}
阻止默認(rèn)行為(event.preventDefault())

有時(shí),你會(huì)遇到一些情況,你希望事件不執(zhí)行它的默認(rèn)行為例如自定義注冊(cè)表單

var form = document.querySelector("form");
var fname = document.getElementById("fname");
var lname = document.getElementById("lname");
var submit = document.getElementById("submit");
var para = document.querySelector("p");
form.onsubmit = function(e) {
  if (fname.value === "" || lname.value === "") {
    e.preventDefault();
    para.textContent = "You need to fill in both names!";
  }
}
事件冒泡及捕獲(event.stopPropagation())
描述事件觸發(fā)時(shí)序問題的術(shù)語(yǔ)。
事件捕獲指的是從document到觸發(fā)事件的那個(gè)節(jié)點(diǎn),即自上而下的去觸發(fā)事件。
事件冒泡是自下而上的去觸發(fā)事件。
綁定事件方法的第三個(gè)參數(shù),就是控制事件觸發(fā)順序是否為事件捕獲。true,事件捕獲;false,事件冒泡。默認(rèn)false,即事件冒泡

事件委托
冒泡還允許我們利用事件委托——這個(gè)概念依賴于這樣一個(gè)事實(shí),如果你想要在大量子元素中單擊任何一個(gè)都可以運(yùn)行一段代碼,您可以將事件監(jiān)聽器設(shè)置在其父節(jié)點(diǎn)上,并將事件監(jiān)聽器氣泡的影響設(shè)置為每個(gè)子節(jié)點(diǎn),而不是每個(gè)子節(jié)點(diǎn)多帶帶設(shè)置事件監(jiān)聽器

如:鼠標(biāo)放到li上對(duì)應(yīng)的li背景變灰

  • item1
  • item2
  • item3
  • item4
  • item5
  • item6

利用事件冒泡實(shí)現(xiàn)

$("ul").on("mouseover",function(e){
     $(e.target).css("background-color","#ffffd").siblings().css("background-color","white");
})

給所有l(wèi)i都綁上事件

$("li").on("mouseover",function(){
      $(this).css("background-color","#ffffd").siblings().css("background-color","white");
})
代碼簡(jiǎn)潔程度上,兩者是相若仿佛的。
前者少了一個(gè)遍歷所有l(wèi)i節(jié)點(diǎn)的操作,所以在性能上肯定是更優(yōu)的
如果在綁定事件完成后,頁(yè)面又動(dòng)態(tài)的加載了一些元素
第二種方案,由于綁定事件的時(shí)候item7還不存在,所以為了效果,我們還要給它再綁定一次事件.
自定義事件(DOM的事件模擬又稱“偽DOM自定義事件”)

js原生自定義事件分三個(gè)階段(創(chuàng)造、初始化、觸發(fā))

摘自 https://developer.mozilla.org...

(1). 創(chuàng)造

var event = document.createEvent(type);
type:是一個(gè)字符串,表示要?jiǎng)?chuàng)建的事件類型。事件類型可能包括是一個(gè)字符串,表示要?jiǎng)?chuàng)建的事件類型。
事件類型可能包括"UIEvents", "MouseEvents", "MutationEvents", 或者 "HTMLEvents"

(2) 初始化

event.initEvent("build", true, true);
于初始化通過DocumentEvent接口創(chuàng)建的Event的值。支持三個(gè)參數(shù):initEvent(eventName, canBubble,preventDefault)
分別表示事件名稱,是否可以冒泡,是否阻止事件的默認(rèn)操作

(3). 觸發(fā)

elem.dispatchEvent(event);
參數(shù)event表示事件對(duì)象,是createEvent()方法返回的創(chuàng)建的Event對(duì)象

監(jiān)聽方法

elem.addEventListener("build", function (e) {
// e.target matches elem
}, false);

jq自定義dom事件

(1). trigger()

常用模擬
  模擬方法操作
   $("#btn").trigger("click");
     或者    
   $("#btn").click();
自定義事件
   $("#btn").on("myClick", function () {
       $("#test").append("

我的自定義事件。

"); }); $("btn").trigger("myClick");
傳遞數(shù)據(jù)
  trigger(tpye[,datea]);
  第一個(gè)參數(shù)是要觸發(fā)的事件類型,
  第二個(gè)單數(shù)是要傳遞給事件處理函數(shù)的附加數(shù)據(jù),以數(shù)組形式傳遞。
  通??梢酝ㄟ^傳遞一個(gè)參數(shù)給回調(diào)函數(shù)來區(qū)別這次事件是代碼觸發(fā)的還是用戶觸發(fā)的
   $("#btn").bind("clickCustomize", function (event, message1, message2) { //獲取數(shù)據(jù)
        $("#test").append("p" + message1 + message2 + "

"); }); $("#btn").trigger("clickCustomize",["我的自定義","事件"]); //傳遞兩個(gè)數(shù)據(jù) $(“#btn”).trigger(“clickCustomize”,["我的自定義","事件"]); //傳遞兩個(gè)數(shù)據(jù)

(2). triggerHandler();(阻止默認(rèn)事件)

triggerHandler("lickCustomize");

DOM自定義事件優(yōu)勢(shì)與劣勢(shì):

(1)、優(yōu)勢(shì):

1、自定義事件完全由我們控制觸發(fā)時(shí)機(jī),這就意味著實(shí)現(xiàn)了一種 JavaScript 的解耦。我們可以把多個(gè)關(guān)聯(lián)但邏輯復(fù)雜的操作利用自定義事件的機(jī)制靈活地控制好
2、既然綁定也可以解綁,如果不需要了,直接移除綁定事件

(2)、劣勢(shì)

1、兼容性差,要自己hack(jq除外)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/107415.html

相關(guān)文章

  • JavaScript疑難雜癥系列-事件循環(huán)

    摘要:而之后事件循環(huán)一直會(huì)去遍歷任務(wù)隊(duì)列,一旦有任務(wù)放入就會(huì)放入主線程中執(zhí)行。任務(wù)隊(duì)列所謂任務(wù)是返回的一個(gè)個(gè)通知,讓主線程在讀取任務(wù)隊(duì)列的時(shí)候得知這個(gè)異步任務(wù)已經(jīng)完成,下一步該執(zhí)行這個(gè)任務(wù)的回調(diào)函數(shù)了。 javascript單線程 瀏覽器端,復(fù)雜的UI環(huán)境會(huì)限制多線程語(yǔ)言的開發(fā)。例如,一個(gè)線程在操作一個(gè)DOM元素時(shí),另一個(gè)線程需要去刪除DOM元素,這個(gè)之間就需要進(jìn)行狀態(tài)的同步,何況前端可能不...

    Keagan 評(píng)論0 收藏0
  • JavaScript疑難雜癥系列-事件

    摘要:支持三個(gè)參數(shù)分別表示事件名稱,是否可以冒泡,是否阻止事件的默認(rèn)操作觸發(fā)參數(shù)表示事件對(duì)象,是方法返回的創(chuàng)建的對(duì)象監(jiān)聽方法自定義事件常用模擬模擬方法操作或者自定義事件我的自定義事件。 事件這塊知識(shí)點(diǎn)雖然是老生長(zhǎng)談的,但對(duì)于我來說多多整理,多多感悟,溫故知新,每次看看這塊都有不同的收獲.(在這里我不會(huì)長(zhǎng)篇大論,只會(huì)挑重點(diǎn);具體的小伙伴們自行查找) 什么是事件 在編程時(shí)系統(tǒng)內(nèi)發(fā)生的動(dòng)作或者發(fā)生...

    CocoaChina 評(píng)論0 收藏0
  • JavaScript疑難雜癥系列-事件

    摘要:支持三個(gè)參數(shù)分別表示事件名稱,是否可以冒泡,是否阻止事件的默認(rèn)操作觸發(fā)參數(shù)表示事件對(duì)象,是方法返回的創(chuàng)建的對(duì)象監(jiān)聽方法自定義事件常用模擬模擬方法操作或者自定義事件我的自定義事件。 事件這塊知識(shí)點(diǎn)雖然是老生長(zhǎng)談的,但對(duì)于我來說多多整理,多多感悟,溫故知新,每次看看這塊都有不同的收獲.(在這里我不會(huì)長(zhǎng)篇大論,只會(huì)挑重點(diǎn);具體的小伙伴們自行查找) 什么是事件 在編程時(shí)系統(tǒng)內(nèi)發(fā)生的動(dòng)作或者發(fā)生...

    quietin 評(píng)論0 收藏0
  • JavaScript疑難雜癥系列-相等性判斷

    摘要:同一類的復(fù)合類型值兩個(gè)復(fù)合類型對(duì)象數(shù)組函數(shù)的數(shù)據(jù)比較時(shí),不是比較它們的值是否相等,而是比較它們是否指向同一個(gè)對(duì)象。寬松相等雙等號(hào)將執(zhí)行類型轉(zhuǎn)換原始類型的值原始類型的數(shù)據(jù)會(huì)轉(zhuǎn)換成數(shù)值類型再進(jìn)行比較。 事件這塊知識(shí)點(diǎn)雖然是老生長(zhǎng)談的,但對(duì)于我來說多多整理,多多感悟,溫故知新,每次看看這塊都有不同的收獲.(在這里我不會(huì)長(zhǎng)篇大論,只會(huì)挑重點(diǎn);具體的小伙伴們自行查找)參考:https://dev...

    Flink_China 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<