久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

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

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

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

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

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

        JavaScript兼容性匯總

        來源:千鋒教育
        發(fā)布人:wjy
        時(shí)間: 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**

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

        解決方法:可以使用 getElementById

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

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

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

        ### 屬性

        - 自定義屬性操作方法

        `getAttribute(name)` 不兼容ie6 7

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

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

        解決方法:

        ```text
        // 個(gè)人建議加加載完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é)點(diǎn)

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

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

        ### 滾動(dòng)距離

        ```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
        // 包含工具條與滾動(dòng)條
        // - document.documentElement.clientWidth / clientHeight
        // 不包含工具條與滾動(dòng)條
        // - window.innerWidth / innerHeight
        // - 使用 outerWidth 和 outerHeight 屬性獲取加上工具條與滾動(dòng)條窗口的寬度與高度
        ```

        ## 事件

        - 事件對(duì)象

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

        - 獲取頁(yè)面中鼠標(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
        ```

        - 阻止默認(rèn)行為

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

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

        tags:
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(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ī)則分析

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

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

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

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

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

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

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

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

        抖音一些視頻為了獲取更多點(diǎn)擊,一些博主機(jī)會(huì)投抖加。其實(shí)抖加的投放沒有絕對(duì)正確的方法,而不同賬號(hào)和視頻投放的策略都是不一樣的,不過一般情...詳情>>

        2023-09-19 08:00:10
        開班信息
        北京校區(qū)
        • 北京校區(qū)
        • 大連校區(qū)
        • 廣州校區(qū)
        • 成都校區(qū)
        • 杭州校區(qū)
        • 長(zhǎng)沙校區(qū)
        • 合肥校區(qū)
        • 南京校區(qū)
        • 上海校區(qū)
        • 深圳校區(qū)
        • 武漢校區(qū)
        • 鄭州校區(qū)
        • 西安校區(qū)
        • 青島校區(qū)
        • 重慶校區(qū)
        • 太原校區(qū)
        • 沈陽(yáng)校區(qū)
        • 南昌校區(qū)
        • 哈爾濱校區(qū)
        金沙县| 吴堡县| 东乌| 千阳县| 德阳市| 阳春市| 达拉特旗| 秦安县| 丁青县| 福贡县| 崇义县| 宁晋县| 塔河县| 于田县| 武宣县| 建阳市| 河池市| 繁峙县| 开远市| 文化| 长丰县| 黔江区| 宝坻区| 竹溪县| 库伦旗| 托克托县| 海南省| 南阳市| 威远县| 兴隆县| 元谋县| 从化市| 东安县| 云霄县| 商城县| 阳信县| 云梦县| 合水县| 界首市| 科尔| 汝南县|