iview在ie9及以上的兼容問(wèn)題解決方案

1.為了能夠支持ES6新語(yǔ)法晚伙,安裝babel-polyfill。

(1)npm install babel-polyfill --save復(fù)制代碼

(2)修改webpack.base.conf.js

修改前entry: { main:'./src/main',},復(fù)制代碼

修改后entry: { main: ["babel-polyfill","./src/main"],},


2.兼容dataset

這是ie10及以下不支持dataset導(dǎo)致的拿愧,而iview的transfer-dom.js使用了這個(gè)屬性

解決辦法:在main.js加入如下代碼


//這是ie10及以下不支持dataset導(dǎo)致的,而iview的transfer-dom.js使用了這個(gè)屬性
if (window.HTMLElement) {
    if (Object.getOwnPropertyNames(HTMLElement.prototype).indexOf('dataset') === -1) {
        Object.defineProperty(HTMLElement.prototype, 'dataset', {
            get: function () {
                var attributes = this.attributes; // 獲取節(jié)點(diǎn)的所有屬性
                var name = [];
                var value = []; // 定義兩個(gè)數(shù)組保存屬性名和屬性值
                var obj = {}; // 定義一個(gè)空對(duì)象
                for (var i = 0; i < attributes.length; i++) { // 遍歷節(jié)點(diǎn)的所有屬性
                    if (attributes[i].nodeName.slice(0, 5) === 'data-') { // 如果屬性名的前面5個(gè)字符符合"data-"
                        // 取出屬性名的"data-"的后面的字符串放入name數(shù)組中
                        name.push(attributes[i].nodeName.slice(5));
                        // 取出對(duì)應(yīng)的屬性值放入value數(shù)組中
                        value.push(attributes[i].nodeValue);
                    }
                }
                for (var j = 0; j < name.length; j++) { // 遍歷name和value數(shù)組
                    obj[name[j]] = value[j]; // 將屬性名和屬性值保存到obj中
                }
                return obj; // 返回對(duì)象
            },
        });
    }
}

3.降級(jí)依賴版本

如果遇到以下錯(cuò)誤:

錯(cuò)誤1:“webpackJsonp”未定義

解決方案:更改webpack-dev-server版本為2.71或更低

npm install --save-dev webpack-dev-server@2.7.1復(fù)制代碼

4.兼容requestAnimationFrame(ie9)

ie9是不支持requestAnimationFrame的,如果你使用了出現(xiàn)錯(cuò)誤拾因,那也沒(méi)關(guān)系,往下看就行了旷余。

解決方案:添加以下代碼到main.js


// window.requestAnimationFrame多瀏覽器兼容問(wèn)題補(bǔ)丁
// http://paulirish.com/2011/requestanimationframe-for-smart-animating/
// http://my.opera.com/emoller/blog/2011/12/20/requestanimationframe-for-smart-er-animating
// requestAnimationFrame polyfill by Erik M?ller. fixes from Paul Irish and Tino Zijdel MIT license
(function () {
    var lastTime = 0;
    var vendors = ['ms', 'moz', 'webkit', 'o'];
    for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) {
        window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame'];
        window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame'];
    }
    if (!window.requestAnimationFrame) {
        window.requestAnimationFrame = function (callback, element) {
            var currTime = new Date().getTime();
            var timeToCall = Math.max(0, 16 - (currTime - lastTime));
            var id = window.setTimeout(function () {
                callback(currTime + timeToCall);
            }, timeToCall);
            lastTime = currTime + timeToCall;
            return id;
        };
    }
    if (!window.cancelAnimationFrame) {
        window.cancelAnimationFrame = function (id) {
            clearTimeout(id);
        };
    }
}());

5.兼容classList(ie9)

錯(cuò)誤信息:無(wú)法獲取未定義或 null 引用的屬性“add”

無(wú)法獲取未定義或 null 引用的屬性“remove”

如果你查看sourceMap發(fā)現(xiàn)了classList().add或classList.remove()等等绢记,那肯定是classList的問(wèn)題了。

解決方案:添加以下代碼到main.js


//解決iview在IE9中l(wèi)ist方法報(bào)錯(cuò)的問(wèn)題
if (!('classList' in document.documentElement)) {
    Object.defineProperty(HTMLElement.prototype, 'classList', {
        get: function () {
            var self = this;
            function update(fn) {
                return function (value) {
                    var classes = self.className.split(/\s+/g);
                    var index = classes.indexOf(value);

                    fn(classes, index, value);
                    self.className = classes.join(' ');
                };
            }

            return {
                add: update(function (classes, index, value) {
                    if (!~index) classes.push(value);
                }),

                remove: update(function (classes, index) {
                    if (~index) classes.splice(index, 1);
                }),

                toggle: update(function (classes, index, value) {
                    if (~index) { classes.splice(index, 1); } else { classes.push(value); }
                }),

                contains: function (value) {
                    return !!~self.className.split(/\s+/g).indexOf(value);
                },

                item: function (i) {
                    return self.className.split(/\s+/g)[i] || null;
                },
            };
        },
    });
}

6.如果請(qǐng)求采用axios正卧,設(shè)置axios傳參數(shù)格式為form-data
(1)安裝axios蠢熄,npm install axios --save
(2)main.js 里:

import axiosfrom 'axios';
axios.defaults.headers.post['Content-Type'] ='application/x-www-form-urlencoded';
axios.defaults.headers.get['Content-Type'] ='application/x-www-form-urlencoded';
axios.defaults.transformRequest = [function (data) {
let ret =''
  for (let itin data) {
ret +=encodeURIComponent(it) +'=' +encodeURIComponent(data[it]) +'&'
  }
return ret
}]

//然后再修改原型鏈
Vue.prototype.$http = axios;

攔截器:

12250765-8c5a1116165401bd.png

7.解決IE9中不支持foreach的解決方法

//解決IE9中不支持foreach的解決方法
if ( !Array.prototype.forEach ) {
    Array.prototype.forEach = function forEach( callback, thisArg ) {
        var T, k;
        if ( this == null ) {
            throw new TypeError( "this is null or not defined" );
        }
        var O = Object(this);
        var len = O.length >>> 0;
        if ( typeof callback !== "function" ) {
            throw new TypeError( callback + " is not a function" );
        }
        if ( arguments.length > 1 ) {
            T = thisArg;
        }
        k = 0;
        while( k < len ) {

            var kValue;
            if ( k in O ) {
                kValue = O[ k ];
                callback.call( T, kValue, k, O );
            }
            k++;
        }
    };
}

8.解決IE中,elementUI的input刪除操作無(wú)法觸發(fā)數(shù)據(jù)變動(dòng)監(jiān)聽(tīng)

解決辦法:加入ie9input事件墊片

(1)安裝:npm install --save ie9-oninput-polyfill

(2)main.js里:

  import oninputPolyfillfrom 'ie9-oninput-polyfill'
   Vue.use(oninputPolyfill);

9.在IE9中,iview的table組件炉旷,在數(shù)據(jù)未加載出來(lái)之前签孔,當(dāng)table內(nèi)容列數(shù)超過(guò)table最大寬度時(shí),頁(yè)面會(huì)不停閃爍砾跃。

解決方法:強(qiáng)制給table組件的.ivu-table-tip添加overflow-x: scroll;

//ie9 閃爍兼容

.ivu-table-tip{

overflow-x: scroll;

}


10.在IE9中,iview的select組件骏啰,當(dāng)選項(xiàng)過(guò)多(選項(xiàng)少時(shí),無(wú)此bug)抽高,出現(xiàn)滾動(dòng)條時(shí)(overflow:auto)判耕,下拉列表的樣式bug。

解決問(wèn)題根據(jù):https://segmentfault.com/a/1190000014639150

解決方法:全局加一個(gè)樣式

/* ie9 樣式兼容*/

.ivu-select-dropdown{

min-width:100%;

display:inline-block;

left:0 !important;

width:auto !important;

}

image
image

11.ie9上vue-cli打包的css加載不了(http://www.reibang.com/p/2c0dafb4455c

npm install --save-dev css-split-webpack-plugin
在webpack.prod.conf.js里

const CSSSplitWebpackPlugin= require('css-split-webpack-plugin').default;
...

//css 分開(kāi)打包

plugins:[
new CSSSplitWebpackPlugin({
size:4000,
  filename:'static/css/[name]-[part].[ext]'
}),
]

12.iview 多選框checkbox樣式翘骂,IE10壁熄,IE11樣式bug;tree組件樣式bug碳竟。

修改方法:全局樣式如下更改草丧。

//checkbox
.ivu-checkbox-checked .ivu-checkbox-inner:after {
  display:block;
  -ms-transform:rotate(45deg)scale(1);/* IE 9 */
  -moz-transform:rotate(45deg)scale(1);/* Firefox */
  -webkit-transform:rotate(45deg)scale(1);/* Safari 和 Chrome */
}
.ivu-checkbox-indeterminate .ivu-checkbox-inner:after {
  display:block;
}

13、如果以上1莹桅,2昌执,14,5,7等兼容配置都加了懂拾,IE仍然報(bào)語(yǔ)法錯(cuò)誤煤禽,請(qǐng)檢查index.html是否加了meta,如下:

<meta http-equiv="X-UA-Compatible" content="IE=Edge">

最重要的檢查項(xiàng)目的更目錄是否有babel的配置文件.babelrc,如果沒(méi)有岖赋,請(qǐng)?jiān)诟夸浶陆ㄎ募麨椤?babelrc”的文件檬果,內(nèi)容如下:

{
  "presets": [
    "es2015",
    ["env", {
      "modules": false,
      "targets": {
        "browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
      }
    }],
    "stage-2"
  ],
  "plugins": ["transform-vue-jsx", "transform-runtime"],
  "env": {
    "test": {
      "presets": ["env", "stage-2"],
      "plugins": ["transform-vue-jsx", "transform-es2015-modules-commonjs", "dynamic-import-node"]
    }
  }
}
image.png

相關(guān)問(wèn)題鏈接:http://www.reibang.com/p/13d5350c6d16

相關(guān)鏈接:https://juejin.im/post/5b94f141f265da0ada5222dc
](https://upload-images.jianshu.io/upload_images/12250765-8c5a1116165401bd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市唐断,隨后出現(xiàn)的幾起案子选脊,更是在濱河造成了極大的恐慌,老刑警劉巖脸甘,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恳啥,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡丹诀,警方通過(guò)查閱死者的電腦和手機(jī)角寸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)忿墅,“玉大人,你說(shuō)我怎么就攤上這事沮峡【纹辏” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵邢疙,是天一觀的道長(zhǎng)棍弄。 經(jīng)常有香客問(wèn)我,道長(zhǎng)疟游,這世上最難降的妖魔是什么呼畸? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮颁虐,結(jié)果婚禮上蛮原,老公的妹妹穿的比我還像新娘。我一直安慰自己另绩,他們只是感情好儒陨,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著笋籽,像睡著了一般蹦漠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上车海,一...
    開(kāi)封第一講書(shū)人閱讀 51,573評(píng)論 1 305
  • 那天笛园,我揣著相機(jī)與錄音,去河邊找鬼。 笑死研铆,一個(gè)胖子當(dāng)著我的面吹牛埋同,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蚜印,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼莺禁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了窄赋?” 一聲冷哼從身側(cè)響起哟冬,我...
    開(kāi)封第一講書(shū)人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎忆绰,沒(méi)想到半個(gè)月后浩峡,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡错敢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年翰灾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片稚茅。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡纸淮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出亚享,到底是詐尸還是另有隱情咽块,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布欺税,位于F島的核電站侈沪,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏晚凿。R本人自食惡果不足惜亭罪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望歼秽。 院中可真熱鬧应役,春花似錦、人聲如沸燥筷。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)荆责。三九已至滥比,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間做院,已是汗流浹背盲泛。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工濒持, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人寺滚。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓柑营,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親村视。 傳聞我的和親對(duì)象是個(gè)殘疾皇子官套,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容