91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

      手機站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

      千鋒教育

      掃一掃進入千鋒手機站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學(xué)習(xí)站小程序
      隨時隨地免費學(xué)習(xí)課程

      當(dāng)前位置:首頁  >  技術(shù)干貨  > JavaScript兼容性匯總

      JavaScript兼容性匯總

      來源:千鋒教育
      發(fā)布人:wjy
      時間: 2022-06-01 15:28:00 1654068480

       一般兼容性問題都體現(xiàn)到DOM和事件上

       只聊ie6+版本瀏覽器,希望小伙伴們別糾結(jié)更低版本瀏覽器哈。

      JavaScript兼容性匯總

      ## DOM

      ### 獲取元素

      - `document.getElementsByclassName` 不兼容ie6 7 8
      - 解決方法:

      ```js
      function getByClass(oParent,sClass) {
        var aResult=[];

        var aEle=oParent.getElementsByTagName("*");

        var re=new RegExp("\\b"+sClass+"\\b","i");

        for (var i=0;i<aEle.length;i++)
        {
           if(re.test(aEle[i].className))
           {
             aResult.push(aEle[i]); 
           }  
        }
        return aResult;
      }
      ```

      - **`document.querySelector` 不兼容ie6 7**

      這個選擇器獲取方法還是很推薦使用的

      解決方法:可以使用 getElementById

      - **`document.querySelectorAll` 不兼容ie6 7**

      這個選擇器獲取方法還是很推薦使用的,和上面不同的事,它是獲取一組元素

      解決方法:可以使用 getElementsByTagName 或者 上面封裝的getByClass

      ### 屬性

      - 自定義屬性操作方法

      `getAttribute(name)` 不兼容ie6 7

      `setAttribute(name,value)` 不兼容ie6 7

      `removeAttribute(name)` 不兼容ie6 7、

      解決方法:

      ```text
      // 個人建議加加載完html,使用js給標(biāo)簽賦值
      obj.index = 1      // 設(shè)置
      console.log(obj.index) // 獲取
      obj.index = ''     // 清空
      ```

      - 自定義屬性data-* 不兼容ie6 7 8 9 10

      console.log(obj.dataset.name) 獲取

      obj.dataset.name = value 設(shè)置

      解決方法:

      ```text
      function getDataset(ele){
          if(ele.dataset){
              return ele.dataset;
          }else{
              var attrs = ele.attributes,
                  dataset = {},
                  name,
                  matchStr;

              for(var i = 0;i<attrs.length;i++){
                  matchStr = attrs[i].name.match(/^data-(.+)/);
                  if(matchStr){
                      name = matchStr[1].replace(/-([\da-z])/gi,function(all,letter){
                          return letter.toUpperCase();
                      });
                      dataset[name] = attrs[i].value;
                  }
              }
              return dataset;
          }
      }
      ```

      - 操作class方法

      classList.add('name') 不兼容ie6 7 8 9

      classList.remove('name') 不兼容ie6 7 8 9

      解決方法:

      ```text
      function addClass(obj, class){
        if(!this.contains(class)){
          obj.className +=' ' + class;
        }
      }
      function removeClass(obj,class){
        if(obj.className.indexOf(class) !== -1){
          var reg= new RegExp(class);  
          obj.className =  obj.className.replace(reg,'');
        }
      }
      ```

      ### 節(jié)點

      - 節(jié)點類一起總結(jié): 前面的不兼容ie6

      ```js
      // 獲取子節(jié)點
      var children = obj.children || obj.childNodes
      // 獲取第一個子節(jié)點
      var first = obj.firstElementChild || obj.firstChild
      // 獲取最后一個子節(jié)點
      var last = obj.lastElementChild || obj.lastChild
      // 獲取上一個兄弟節(jié)點
      var prev = obj.previousElementSibling || obj.nextElementSibling
      // 獲取下一個兄弟節(jié)點
      var next = obj.nextElementSibling || obj.nextElementSibling
      ```

      ### 滾動距離

      ```js
      // 有文檔頭
      // - docuemnt.documentElement.scrollTop / scrollLeft
      // 沒有文檔頭
      // - document.body.scrollTop / scrollLeft

      // 兼容
      var top = docuemnt.documentElement.scrollTop || document.body.scrollTop
      var left = docuemnt.documentElement.scrollLeft || document.body.scrollLeft
      ```

      - 瀏覽器可視區(qū)大小

      ```js
      // 包含工具條與滾動條
      // - document.documentElement.clientWidth / clientHeight
      // 不包含工具條與滾動條
      // - window.innerWidth / innerHeight
      // - 使用 outerWidth 和 outerHeight 屬性獲取加上工具條與滾動條窗口的寬度與高度
      ```

      ## 事件

      - 事件對象

      ```text
      // 事件對象
      // ev 不兼容ie 6 7 8
      // window.event 兼容所有瀏覽器
      document.onclick = function (ev) {
          ev = ev || window.event
      }
      ```

      - 獲取頁面中鼠標(biāo)位置

      `ev.pageX/ev.pageY` 不兼容ie6 7 8

      解決方案:

      ```text
      var x = ev.clientX + document.documentElement.scrollLeft
      var y = ev.clientY + document.documentElement.scrollTop
      ```

      - 獲取鍵盤碼

      `ev.keyCode` 不兼容火狐

      `ev.which` 不兼容 ie6 7 8

      解決方案:

      ```text
       var code = keyCode || which
      ```

      - 獲取事件源

      `ev.target` 不兼容 ie6 7 8

      `ev.srcElement` 兼容所有瀏覽器

      解決方案:

      ```text
       var src = target || srcElement
      ```

      - 阻止默認行為

      `ev.preventDefault()` 不兼容ie6 7 8

      `ev.returnValue = false` 兼容所有瀏覽器

      解決方案:

      ```text
      function stopDefault(ev) {
          if (ev && ev.preventDefault) {
              ev.preventDefault()
          } else {
              event.returnValue = false
          }
          return false;
      }
      ```

      - 阻止事件冒泡

      `e.stopPropagation()` 不兼容ie6 7 8

      `ev.cancelBubble = true` 兼容所有瀏覽器

      解決方案:

      ```text
      function stopPropagat(ev){
          if (ev&& evstopPropagation) {
              evstopPropagation()
          } else {
              event.cancelBubble = true
          }
      }
      ```

      - 事件綁定

      `obj.addEventListener` 不兼容9+

      `obj.attachEvent` 兼容ie6 7 8

      解決方案:

      ```text
      function on(obj, type, fn){
          if(obj.addEventListener){  
              obj.addEventListener(type, fn, false)
          }else{
              obj.attachEvent('on'+type, fn)
          }
      }
      ```

      - 事件解除綁定

      `obj.removeEventListener` 不兼容9+

      `obj.detachEvent` 兼容ie6 7 8

      解決方案:

      ```text
      function on(obj, type, fn){
          if(obj.removeEventListener){  
              obj.removeEventListener(type, fn, false)
          }else{
              obj.detachEvent('on'+type, fn)
          }
      }
      ```

      整理不易,如有遺漏還請多多包涵。更多關(guān)于“html5培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗,課程大綱更科學(xué)更專業(yè),有針對零基礎(chǔ)的就業(yè)班,有針對想提升技術(shù)的提升班,高品質(zhì)課程助理你實現(xiàn)夢想。

      tags:
      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
      請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
      免費領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學(xué) 138****2860 剛剛成功領(lǐng)取
      王同學(xué) 131****2015 剛剛成功領(lǐng)取
      張同學(xué) 133****4652 剛剛成功領(lǐng)取
      李同學(xué) 135****8607 剛剛成功領(lǐng)取
      楊同學(xué) 132****5667 剛剛成功領(lǐng)取
      岳同學(xué) 134****6652 剛剛成功領(lǐng)取
      梁同學(xué) 157****2950 剛剛成功領(lǐng)取
      劉同學(xué) 189****1015 剛剛成功領(lǐng)取
      張同學(xué) 155****4678 剛剛成功領(lǐng)取
      鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
      董同學(xué) 138****2867 剛剛成功領(lǐng)取
      周同學(xué) 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      今日頭條展現(xiàn)量是什么?今日頭條展現(xiàn)量規(guī)則分析

      目前頭條用戶會發(fā)現(xiàn)微頭條和問答新增了“展現(xiàn)量”指標(biāo)。那么這個今日頭條展現(xiàn)量是什么意思呢?如何提高呢?下面千鋒教育小編就和大家說...詳情>>

      2023-09-19 09:15:47
      我想直播帶貨去哪里找貨源一件代發(fā)

      現(xiàn)在直播帶貨是一個非?;鸬男袠I(yè),越來越多的人進入到這個圈子,但是,認真地說,直播帶貨能不能賺到錢還是要看自己。雖然這一行業(yè)火,收入高,...詳情>>

      2023-09-19 08:41:02
      入駐短視頻mcn需要多少錢?有哪些費用?

      眾所周知,現(xiàn)在短視頻成了很多人的自媒體創(chuàng)業(yè)道路之一,越來越多人喜歡在網(wǎng)上消遣時間,購物等。也有很多優(yōu)秀的博主去做出很多新的內(nèi)容,那么入...詳情>>

      2023-09-19 08:12:47
      短視頻帶貨應(yīng)該注冊什么公司?需要什么資料?

      短視頻大家應(yīng)該都非常熟悉,現(xiàn)在很多人都喜歡在閑暇的時候刷短視頻,短視頻平臺也開始了直播帶貨,商家也都開始創(chuàng)業(yè)了,那么短視頻帶貨需要營業(yè)...詳情>>

      2023-09-19 08:09:31
      怎樣投抖加不花錢?別人能看出來嗎?

      抖音一些視頻為了獲取更多點擊,一些博主機會投抖加。其實抖加的投放沒有絕對正確的方法,而不同賬號和視頻投放的策略都是不一樣的,不過一般情...詳情>>

      2023-09-19 08:00:10
      開班信息
      北京校區(qū)
      • 北京校區(qū)
      • 大連校區(qū)
      • 廣州校區(qū)
      • 成都校區(qū)
      • 杭州校區(qū)
      • 長沙校區(qū)
      • 合肥校區(qū)
      • 南京校區(qū)
      • 上海校區(qū)
      • 深圳校區(qū)
      • 武漢校區(qū)
      • 鄭州校區(qū)
      • 西安校區(qū)
      • 青島校區(qū)
      • 重慶校區(qū)
      • 太原校區(qū)
      • 沈陽校區(qū)
      • 南昌校區(qū)
      • 哈爾濱校區(qū)