iview在ie9及以上的兼容问题解决方案

1.为了能够支持ES6新语法,安装babel-polyfill。

(1)npm install babel-polyfill --save复制代码

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

修改前entry: {    main:'./src/main',},复制代码

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


2.兼容dataset

这是ie10及以下不支持dataset导致的,而iview的transfer-dom.js使用了这个属性

解决办法:在main.js加入如下代码

```

//这是ie10及以下不支持dataset导致的,而iview的transfer-dom.js使用了这个属性

if (window.HTMLElement) {

if (Object.getOwnPropertyNames(HTMLElement.prototype).indexOf('dataset') === -1) {

Object.defineProperty(HTMLElement.prototype, 'dataset', {

get:function () {

var attributes =this.attributes; // 获取节点的所有属性

                var name = [];

                var value = []; // 定义两个数组保存属性名和属性值

                var obj = {}; // 定义一个空对象

                for (var i =0; i < attributes.length; i++) {// 遍历节点的所有属性

                    if (attributes[i].nodeName.slice(0, 5) ==='data-') {// 如果属性名的前面5个字符符合"data-"

// 取出属性名的"data-"的后面的字符串放入name数组中

                        name.push(attributes[i].nodeName.slice(5));

                        // 取出对应的属性值放入value数组中

                        value.push(attributes[i].nodeValue);

                    }

}

for (var j =0; j < name.length; j++) {// 遍历name和value数组

                    obj[name[j]] = value[j]; // 将属性名和属性值保存到obj中

                }

return obj; // 返回对象

            },

        });

    }

}

```

3.降级依赖版本

如果遇到以下错误:

错误1:“webpackJsonp”未定义

解决方案:更改webpack-dev-server版本为2.71或更低

npm install --save-dev webpack-dev-server@2.7.1复制代码

4.兼容requestAnimationFrame(ie9)

ie9是不支持requestAnimationFrame的,如果你使用了出现错误,那也没关系,往下看就行了。

解决方案:添加以下代码到main.js

```

// window.requestAnimationFrame多浏览器兼容问题补丁

// 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)

错误信息:无法获取未定义或 null 引用的属性“add”

无法获取未定义或 null 引用的属性“remove”

如果你查看sourceMap发现了classList().add或classList.remove()等等,那肯定是classList的问题了。

解决方案:添加以下代码到main.js

```

//解决iview在IE9中list方法报错的问题

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.如果请求采用axios,设置axios传参数格式为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;

拦截器:

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 ( kin O ) {

kValue = O[ k ];

                callback.call( T, kValue, k, O );

            }

k++;

        }

};

}

```

8.解决IE中,elementUI的input删除操作无法触发数据变动监听

解决办法:加入ie9input事件垫片

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

(2)main.js里:

       import oninputPolyfillfrom 'ie9-oninput-polyfill'

       Vue.use(oninputPolyfill);


9.在IE9中,iview的table组件,在数据未加载出来之前,当table内容列数超过table最大宽度时,页面会不停闪烁。

解决方法:强制给table组件的.ivu-table-tip添加overflow-x: scroll;

//ie9 闪烁兼容

.ivu-table-tip{

 overflow-x: scroll;

}


10.在IE9中,iview的select组件,当选项过多(选项少时,无此bug),出现滚动条时(overflow:auto),下拉列表的样式bug。

解决问题根据:https://segmentfault.com/a/1190000014639150

解决方法:全局加一个样式

/* ie9 样式兼容*/

.ivu-select-dropdown{

min-width:100%;

  display:inline-block;

  left:0 !important;

  width:auto !important;

}


11.ie9上vue-cli打包的css加载不了(https://www.jianshu.com/p/2c0dafb4455c)

npm install --save-dev css-split-webpack-plugin

在webpack.prod.conf.js里

```

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

...

//css 分开打包

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;

}

```

相关问题链接:https://www.jianshu.com/p/13d5350c6d16

相关链接:https://juejin.im/post/5b94f141f265da0ada5222dc

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,519评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,842评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,544评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,742评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,646评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,027评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,513评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,169评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,324评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,268评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,299评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,996评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,591评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,667评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,911评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,288评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,871评论 2 341

推荐阅读更多精彩内容