国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

詳解Vue iview IE瀏覽器不兼容報錯(Iview Bable polyfill)

2024-05-06 15:43:30
字體:
供稿:網(wǎng)友

由于Iview編譯使用到了es6的一些新特性,Internet Explorer所有版本中都會報錯,缺少includes、findIxdex等問題。

本人研究涉及到的環(huán)境:VueCli3.2 + iview 3.1.5

在IE中不支持ES6的新特性,例如:includes、findIndex……

以下方案可以解決該問題:

1.  Github iview倉儲Issues中提到的

改編譯范圍請用 transpileDependencies: [‘iview'],不要用 include.add,因為默認配置里用了 exclude,在 webpack 中,多個條件同時存在時需要每個條件都滿足才執(zhí)行 rule。

但是加了這個選項后在所有瀏覽器里都會報錯,因為 iView 里這個文件不兼容 ES Module。該文件是用很舊版本的 UMD 格式打包的,新版本 UMD 修復(fù)了報錯的問題,但沒有解決和 ES Module 互操作的問題。在 Webpack 4 中,ES Module 不能和 CommonJS / UMD 混用。

所以這里本質(zhì)上是 iView 對 Webpack 4 支持的問題,讓他們把源碼全部轉(zhuǎn)成 ES Module 就好了。
在vue.config.js中添加transpileDependencies: [‘iview']后,可以讓bable編譯過程中檢查iview的代碼,自動添加代碼中用到的polyfill。

但是由于iview中有一個文件使用的UMD打包,所以編譯后的代碼還是在運行環(huán)境中報錯,導(dǎo)致項目無法使用。

該方案雖然解決了ES6語法問題,但是實際使用會報錯。

2.  直接給代碼添加polyfill

修改bable.config.js使用 useBuiltIns: ‘entry'

module.exports = {presets: [ ['@vue/app', {useBuiltIns:'entry'} ] ]}

在Vue入口文件main中導(dǎo)入bable的polyfill

import'@babel/polyfill';

這種方案bable編譯時,會自動導(dǎo)入目標瀏覽器(browserslist中配置)需要用到的polyfill,可以保證全局代碼使用都可以新ES代碼。但是,也許有些polyfill會一直用不到,額外增加了編譯后的文件體積。

3.  使用balbe env,預(yù)置iview中所需要的polyfill(推薦做法)

修改bable.config.js 添加預(yù)導(dǎo)入的polyfill。目前我的項目中用到的polyfill有'es6.promise',‘es6.array.find-index',‘es7.array.includes',‘es6.string.includes'

module.exports = { presets: [ ['@vue/app', {  debug:true,  polyfills: [ 'es6.promise' , 'es6.array.find-index' , 'es7.array.includes' , 'es6.string.includes' ]  } ] ]}

這種方案依然使用Vue項目默認方案,不同的是在項目編譯時,會導(dǎo)入polyfills中指定的polyfill,這樣既可解決iview在ie中運行報錯的問題。

上面中是我目前用到的幾polyfill,如果需要其它鋪墊,可以自行添加。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持錯新站長站。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 吉木乃县| 京山县| 确山县| 鄂伦春自治旗| 临潭县| 安康市| 和硕县| 离岛区| 耿马| 神池县| 湖南省| 屏东县| 衡阳市| 旌德县| 新平| 抚松县| 宣恩县| 黑水县| 临潭县| 宜昌市| 禹州市| 砀山县| 澜沧| 江山市| 额敏县| 湘潭县| 揭阳市| 黄陵县| 正镶白旗| 从江县| 巨鹿县| 闽侯县| 台州市| 鄂托克前旗| 石泉县| 临泉县| 北票市| 苍溪县| 棋牌| 蓝山县| 台东县|