国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-27 22:33:53
文檔

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

js學習總結之DOM2兼容處理順序問題的解決方法:DOM2兼容處理順序問題的解決方法,具體如下 解決順序問題:我們不用瀏覽器自帶的事件池了,而是自己模擬標準瀏覽器的事件池實現,具體代碼如下: /* bind:處理DOM2級事件綁定的兼容性問題(綁定方法) @parameter: curEle->要綁定事件的元素 ev
推薦度:
導讀js學習總結之DOM2兼容處理順序問題的解決方法:DOM2兼容處理順序問題的解決方法,具體如下 解決順序問題:我們不用瀏覽器自帶的事件池了,而是自己模擬標準瀏覽器的事件池實現,具體代碼如下: /* bind:處理DOM2級事件綁定的兼容性問題(綁定方法) @parameter: curEle->要綁定事件的元素 ev

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);
 }
}

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

js學習總結之DOM2兼容處理順序問題的解決方法:DOM2兼容處理順序問題的解決方法,具體如下 解決順序問題:我們不用瀏覽器自帶的事件池了,而是自己模擬標準瀏覽器的事件池實現,具體代碼如下: /* bind:處理DOM2級事件綁定的兼容性問題(綁定方法) @parameter: curEle->要綁定事件的元素 ev
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 日韩欧| 在线观看色网站 | 日韩免费在线观看视频 | 久久久午夜 | 伊人久久综合网亚洲 | 久久国产精品一区二区三区 | 久久国产热 | 亚洲精品98久久久久久中文字幕 | 国产欧美日韩亚洲 | 亚洲色图欧美色 | 国产伦精品一区二区三区免 | 国产精品成人va | 欧美激情二区 | 国产一级片免费看 | 另类专区另类专区亚洲 | 亚洲另类中文字幕 | 国产欧美日韩一区二区三区 | 欧美一区二区三区不卡免费 | 九九久久香港经典三级精品 | 久色视频在线 | 伊人一区 | 亚洲国产欧美在线 | 欧美日韩精品在线视频 | 中文在线第一页 | 欧美在线一区二区三区精品 | 午夜一级 | 国产成人亚洲综合一区 | 国产精品伦一区二区三级视频 | 欧美精品一区二区在线观看 | 黄色视频毛片 | 国产一区二区三区视频在线观看 | 黄色国产网站 | 免费一看一级毛片人 | 国产 欧美 在线 | 欧美日本一本 | 欧美日韩一区二区在线观看 | 日韩欧美一区二区三区不卡在线 | 日本免费一区二区三区 | 亚洲欧美综合网站 | 亚洲十欧美十日韩十国产 | 欧美日韩色 |