- js兼容 man.js導(dǎo)入即可
export default function (vue) {
if (Number.parseInt === undefined) Number.parseInt = window.parseInt;
if (Number.parseFloat === undefined) Number.parseFloat = window.parseFloat;
if (window.HTMLElement) {
if (Object.getOwnPropertyNames(HTMLElement.prototype).indexOf('dataset') === -1) {
Object.defineProperty(HTMLElement.prototype, 'dataset', {
get: function () {
var attributes = this.attributes; // 獲取節(jié)點的所有屬性
var name = [];
var value = []; // 定義兩個數(shù)組保存屬性名和屬性值
var obj = {}; // 定義一個空對象
for (var i = 0; i < attributes.length; i++) { // 遍歷節(jié)點的所有屬性
if (attributes[i].nodeName.slice(0, 5) === 'data-') { // 如果屬性名的前面5個字符符合"data-"
// 取出屬性名的"data-"的后面的字符串放入name數(shù)組中
name.push(attributes[i].nodeName.slice(5));
// 取出對應(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; // 返回對象
},
});
}
};
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;
},
};
},
});
}
// window.requestAnimationFrame多瀏覽器兼容問題補(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
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);
};
}
// router-link 兼容
if (
'-ms-scroll-limit' in document.documentElement.style &&
'-ms-ime-align' in document.documentElement.style
) { // detect it's IE11
window.addEventListener("hashchange", function (event) {
var currentPath = window.location.hash.slice(1);
if (vue.$route.path !== currentPath) {
vue.$router.push(currentPath)
}
}, false)
}
}
-
下載es6-promise ie-placeholder依賴并導(dǎo)入
// main.js 中使用 es6-promise
promise.polyfill()
- 下載iview并配置模塊化引入
//.babelrc 添加plugins
{
"presets": [
["env", {
"modules": false,
"targets": {
"browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
}
}],
"stage-2"
],
"plugins": ["transform-vue-jsx", "transform-runtime",
["import", {
"libraryName": "iview",
"libraryDirectory": "src/components"
}]
]
}
//vue-loader.config.js 修改extract
//npm install extract-text-webpack-plugin --save-dev
loaders: utils.cssLoaders({
sourceMap: sourceMapEnabled,
extract: true //提取css到單個文件
})
//webpack.base.conf.js 修改入口
entry: {
// app: './src/main.js'
app: ["babel-polyfill", "./src/main"]
},
//webpack.dev.conf.js 添加新配置
const ExtractTextPlugin = require('extract-text-webpack-plugin')
new ExtractTextPlugin({
filename: utils.assetsPath('css/[name].[contenthash].css'),
allChunks: true,
})