這篇文章主要介紹Webpack4+Babel7+ES6兼容IE8的示例分析,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)是一家專注于成都做網(wǎng)站、網(wǎng)站建設(shè)與策劃設(shè)計,吳起網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:吳起等地區(qū)。吳起做網(wǎng)站價格咨詢:028-86922220ES6兼容IE8需要解決四個問題
語法支持
IE瀏覽器不支持ES6的語法,只在IE10、IE11中支持了部分ES6的API,所以在IE瀏覽器中使用ES6需要把ES6的代碼編譯成ES5才能執(zhí)行。方法也很簡單,就是用babel-loader。這部分沒什么坑,所以我也就不細(xì)說了。給個網(wǎng)站,大家可以自行查看ES5、ES6在各瀏覽器版本中的支持情況
https://kangax.github.io/compat-table/es6/
ES3保留關(guān)鍵字
如果在IE8下通過object.propertyName的方式使用ES3中的保留關(guān)鍵字(比如default、class、catch),就會報錯
SCRIPT1048: 缺少標(biāo)識符
webpack有一款loader插件es3ify-loader專門用來處理ES3的關(guān)鍵字兼容問題。這個插件的作用就是把這些保留字給你加上引號,使用字符串的形式引用。
// 編譯前 function(t) { return t.default; } // 編譯后 function(t) { return t["default"]; }
然而,筆者親身實踐后發(fā)現(xiàn),UglifyJS本來就已經(jīng)提供了對IE瀏覽器的支持,不需要額外引入es3ify-loader。webpack默認(rèn)的UglifyJS配置不支持ie8,需要手動配下。
{ mode: 'production', optimization: { minimizer: [ new UglifyJsPlugin({ uglifyOptions: { ie8: true } }) ] } }
執(zhí)行環(huán)境
解決了前面兩個問題只能保證語法上不報錯,但使用ES6中的API(比如Promise)還是會報錯。另外,IE8對ES5的API支持也很差,只支持了少量的API,有些API還只是支持部分功能(比如Object.defineProperty)。所以,要在IE8中完美運(yùn)行ES6的代碼,不僅需要填充ES6的API,還要填充ES5的API。
babel為此提供了兩種解決方案: @babel/polyfill、@babel/runtime。具體使用方法官方文檔已經(jīng)寫的很詳細(xì)了,筆者就不贅述了。這里糾正墨白同學(xué)文中的一個錯誤,就是@babel/polyfill現(xiàn)在已經(jīng)支持按需加載,準(zhǔn)確的說也不能算是錯誤,因為墨白同學(xué)在寫這篇文章的時候還不支持按需加載。具體方法我就不細(xì)說了,文檔里都有,配置下browserlist和@babel/preset-env的useBuiltsIns屬性就可以了。
我只說下我在實際開發(fā)過程中碰到的坑。
雖然@babel/polyfill、@babel/runtime都支持按需加載,但都只能識別出業(yè)務(wù)代碼中使用到的缺失的API,如果第三方庫有用到這些缺失的API,babel不能識別出來,自然也就不能填充進(jìn)來。比如regenerator-runtime中用到的Object.create和Array.prototype.forEach。解決辦法是,在入口文件處手動引入缺失的API。
模塊化加載
筆者原來是想用ES6的模塊化加載方案,因為這樣可以利用webpack的tree shaking,移除冗余代碼,使打包出來的文件體積更小。但在IE8下測試發(fā)現(xiàn)Object.defineProperty會報錯'Accessors not supported!'。報錯代碼如下
if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported!');
我用@babel/plugin-transform-modules-commonjs轉(zhuǎn)成commonjs加載就可以把這個坑繞過去,但同時也意味著放棄了tree shaking。
總結(jié)
package.json
{ "devDependencies": { "@babel/core": "^7.2.2", "@babel/plugin-transform-runtime": "^7.2.0", "@babel/preset-env": "^7.1.0", "@babel/runtime": "^7.3.4", "babel-loader": "^8.0.4", "core-js": "^3.0.1", "uglifyjs-webpack-plugin": "^2.0.1", "webpack": "^4.20.2", "webpack-cli": "^3.1.2", "webpack-dev-server": "^3.1.9", "webpack-merge": "^4.1.4" } }
webpack配置
{ module: { rules: [ { test: /\.js$/, exclude: /(node_modules|bower_components)/, use: { loader: 'babel-loader', options: { presets: [ '@babel/preset-env' ], plugins: [ [ '@babel/plugin-transform-runtime' ], [ // 筆者為了兼容IE8才用了這個插件,代價是不能tree shaking // 沒有IE8兼容需求的同學(xué)可以把這個插件去掉 '@babel/plugin-transform-modules-commonjs' ] ] } } } ] }, optimization: { minimizer: [ new UglifyJsPlugin({ sourceMap: true, uglifyOptions: { ie8: true, } }) ] } }
入口文件按需引入缺失的API
require('core-js/features/object/define-property') require('core-js/features/object/create') require('core-js/features/object/assign') require('core-js/features/array/for-each') require('core-js/features/array/index-of') require('core-js/features/function/bind') require('core-js/features/promise')
以上是“Webpack4+Babel7+ES6兼容IE8的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。