中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js學習總結之DOM2兼容處理順序問題的解決方法

發布時間:2020-09-18 17:39:53 來源:腳本之家 閱讀:118 作者:diasa 欄目:web開發

DOM2兼容處理順序問題的解決方法,具體如下

解決順序問題:我們不用瀏覽器自帶的事件池了,而是自己模擬標準瀏覽器的事件池實現,具體代碼如下:

/*
 bind:處理DOM2級事件綁定的兼容性問題(綁定方法)
 @parameter:
  curEle->要綁定事件的元素
  evenType->要綁定的事件類型("click","mouseover")
  evenFn->要綁定的方法
*/
function bind(curEle,evenType,evenFn){
 if('addEventListener' in document){
  curEle.addEventListener(evenType,evenFn,false);
  return;
 }
 //給evenFn化妝 并且把化妝前的照片貼在自己對應的腦門上
 var tempFn = function(){
  evenFn.call(curEle)
 }
 tempFn.photo = evenFn;
 //首先判斷自定義屬性之前是否存在,不存在的話創建一個,由于要存儲多個化妝后的結果,所以我們讓其值是一個數組
 if(!curEle["mybind"+evenType]){//根據不同的事件類型是不同的數組
  curEle["mybind"+evenType] = [];
 }
 //解決重復問題:每一次自己在往自定義屬性對應的容器中添加前,看一下是否已經存在,存在的話就不用重新的添加了,同理也不需要往事件池里面存儲了
 var ary = curEle["mybind"+evenType];
 for(var i = 0;i<ary.length;i++){
  var cur = ary[i];
  if(cur.photo === evenFn){
   return;
  }
 }
 ary.push(tempFn);
 curEle.attachEvent("on"+evenType,tempFn);
 //這里的開始想法是改變this的指向,把this不指向window
 /*
  box.attachEvent("onclick",function(){
   fn1.call(box)
  })
  這樣雖然解決了this的問題,但是又拋出了一個新的問題,不知道該如何刪除了(我們不知道匿名函數是誰)
  var tempFn = function(){
   fn1.call(box)
  }
  box.attachEvent("onclick",tempFn);
  box.detachEvent("onclick",tempFn);
 */
}

function unbind(curEle,evenType,evenFn){
 if('removeEventListener' in document){
  curEle.removeEventListener(evenType,evenFn,false);
  return;
 }
 //拿evenFn到curEle["myBind"]這里找化妝后的結果,找到之后再事件池中把化妝后的結果移除事件池
 var ary = curEle['myBind'+evenType];
 for(var i = 0;i<ary.length;i++){
  if(ary[i].photo===evenFn){
   ary.splice(i,1)//找到后 把自己存儲的容器中對應的移除掉
   curEle.detachEvent("on"+evenType,ary[i]);//在把事件池中對應的也移除掉
   break;
  }
 }
 
}
//創建事件池,并且把需要給當前元素綁定的方法依次的增加到事件池中
function on(curEle,evenType,evenFn){
 if(!curEle["myEvent"+evenType]){
  curEle["myEvent"+evenType] = [];
 }
 var ary = curEle["myEvent"+evenType];
 for(var i = 0;i<ary.length;i++){
  var cur = ary[i];
  if(cur===evenFn){
   return;
  }
 }
 ary.push(evenFn);
 //執行on的時候,我們給當前元素綁定了一個點擊的行為,當點擊的時候執行run方法:run方法中的this是當前元素curEle,并且瀏覽器給run傳遞一個MouseEvent事件對象
 // curEle.addEventListener(evenType,run,false);
 bind(curEle,evenType,run)

}
//在自己的事件池中把某一個方法移除
function off(curEle,evenType,evenFn){
 var ary = curEle["myEvent"+evenType];
 for(var i = 0;i<ary.length;i++){
  var cur = ary[i];
  if(cur===evenFn){
   ary.splice(i,1);
   break;

  }
 }
}
//我們只給當前元素的點擊行為綁定一個方法run,當觸發點擊的時候執行的是run方法,我在run方法中根據自己存儲的方法順序分別的在把這些方法執行

function run(e){
 // this 當前點擊的對象curEle
 e = e || window.event;
 var flag = e.target?true:false;
 if(!flag){
  e.target = e.srcElement;

 }
 //獲取自己事件池中綁定的那些方法,并且讓這些方法依次的執行就可以了
 var ary = this["myEvent"+e.type];//e.target也代表curEle
 for(var i = 0;i<ary.length;i++){
  var tempFn = ary[i];
  tempFn.call(this,e);
 }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

北海市| 黄陵县| 漠河县| 屯门区| 浦北县| 金堂县| 开封县| 沙河市| 黔江区| 海原县| 陆丰市| 东乌珠穆沁旗| 开封县| 宽城| 松阳县| 彝良县| 阜城县| 江北区| 三江| 太湖县| 临高县| 云龙县| 博客| 包头市| 平度市| 青岛市| 微山县| 仙游县| 大洼县| 新蔡县| 旺苍县| 观塘区| 广州市| 永安市| 乌鲁木齐市| 忻州市| 正安县| 饶阳县| 长葛市| 马边| 萝北县|