document-->body-->div-->div-->body-->document-->window比較特殊的,在DOM事件模型中,文本節(jié)點也會觸發(fā)事件,而IE中是不會的。wind" />

黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

javascript 跨瀏覽器的一些小技巧

系統(tǒng) 4537 0

??? 用網(wǎng)頁調(diào)整格式實在是太復(fù)雜了,湊合看看吧。。。。。

  1. ? 事件處理分為兩種,一種為冒泡型事件,另一種為捕獲型事件
    ?
    冒泡型事件 :是從特定目標(biāo)到最不特定的目標(biāo)
    ?
    捕獲型事件 :是從最不特定的對象開始觸發(fā),一直到最精確的對象。
    ?
    ?DOM
    標(biāo)準(zhǔn)同時支持兩種事件,并且捕獲型事件先發(fā)生。
    ?window-->document-->body-->div-->div-->body-->document-->window
    ?
    ?
    比較特殊的,在 DOM 事件模型中,文本節(jié)點也會觸發(fā)事件,而 IE 中是不會的。
    ?window-->document-->body-->div-->text-->text-->div-->body-->document-->window
    ?
    ?
  2. IE DOM 在事件及事件處理中有很多不一樣的。
  • ? 對于加載監(jiān)聽和移除監(jiān)聽的語法
    ?
    IE 中使用
    ??[Object].attachEvent("name_of_event_handler", fnHandler);
    ??[Object].detachEvent("name_of_event_handler", fnHandler);
    ?
    兩個參數(shù):要分配的事件處理函數(shù)的名字 事件處理函數(shù)
    ??[Object].attachEvent("onclick", fnHandler);
    ??
    [Object].onclick = fnHandler; 的作用是一樣的。
    ??
    ?
    DOM 中使用
    ??[Obejct].addEventListener("name_of_event", fnHandler, bCapture);
    ??[Obejct].removeEventListener("name_of_event", fnHandler, bCapture);
    ?
    三個參數(shù): 1 :事件名稱。 2 :事件處理函數(shù)。 3 :用于冒泡階段( false )或者用于捕獲階段( true )。
    ??[Obejct].addEventListener("click", fnHandler, false);
    ??
    [Obejct].onclick = fnHandler; 的作用是一樣的。
    ??
    ?
  • 對于獲取目標(biāo)的方法
    ?
    IE
    ??var oTarget = oEvent.srcElement;
    ?
    DOM
    ??var oTarget = oEvent.target;
    ??
    ??
  • 對于獲取字符代碼

????在 IE

????? 如果按鍵代表一個字符(非 Shift Ctrl Alt 等),則 keyCode 將返回字符的代碼,即 Unicode 值。

DOM
?? ??? ??????
獲得字符代碼用 charCode?

var iCharCode = oEvent.charCode;
?? ??? ??????
獲得字符使用 ??

?var sChar = String.fromCharCode(oEvent.charCode);
?? ??????????
如果不確定按鍵是否包含字符,則使用 isChar 來判斷
???if(oEvent.isChar){
????var iCharCode = oEvent.charCode;
???}
?
?

  • 阻止事件的默認(rèn)行為 ( 比如阻止鼠標(biāo)右鍵等 )
    ?
    IE
    ??oEvent.returnValue = false;
    ?
    DOM
    ??oEvent.preventDefault();
    ?
    ?
  • 停止事件冒泡
    ?
    IE
    ??oEvent.cancelBubble = true;
    ?
    DOM
    ??oEvent.stopPropagation();

    IE DOM 在事件及事件處理中有很多不一樣的。

IE Event 事件統(tǒng)一成 DOM 的形式,創(chuàng)建 formatEvent 方法。建立 EventUtil
?
?

    EventUtil.formatEvent = function (oEvent){
  if(isIE){
   oEvent.charCode = (oEvent.type == "keypress") ? oEvent.keyCode : 0;
   oEvent.eventPhase = 2; //代表冒泡階段,IE僅支持冒泡階段
   oEvent.isChar = (oEvent.charCode > 0);
   oEvent.pageX = oEvent.clientX + document.body.scrollLeft;
   oEvent.pageY = oEvent.clientY + document.body.scrollTop;
   oEvent.preventDefault = function (){
    this.returnvalue = false;
   }
   if(oEvent.type == "mouseout"){
    oEvent.relatedTarget = oEvent.toElement;
   }else if(oEvent.type == "mouseover"){
    oEvent.relatedTarget = oEvent.fromElement;
   }
   oEvent.stopPropagation = function (){
    this.cancelBubble = true;
   }
   oEvent.target = oEvent.srcElement;
   oEvent.time = (new Date).getTime();
  }
  return oEvent;
 }

  

?
?IE

DOM event 獲取方法也不大一樣。特別說明的是函數(shù)的 caller 屬性。每個函數(shù)都有 caller 屬性,指向調(diào)用它的方法的引用。即, funcA() 調(diào)用 funcB(),funcB.caller 就等于 funcA
?

    EventUtil.getEvent = function(){
  if(window.event){
   return this.formatEvent(window.event);
  }else{
   return EventUtil.getEvent.caller.arguments[0];//event對象總是事件處理函數(shù)的第一個參數(shù)。
  }
 }

  

?

?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?

?

?

javascript 跨瀏覽器的一些小技巧


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論