亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

Webpack4+Babel7+ES6兼容IE8的實現

2024-05-06 16:49:47
字體:
來源:轉載
供稿:網友

前陣子重構了一個挺有意思的項目,是一個基于瀏覽器環境的數據采集sdk。公司各個產品的前端頁面中都嵌入了這個sdk,用于采集用戶的行為數據,上傳到公司的大數據平臺,為后續的運營決策分析提供數據支撐。

筆者接手這個項目的時候,前任開發者已經把功能都寫差不多了。唯一需要做的就是做下模塊化拆分和代碼規范,以便后續的開發維護。模塊化拆分用webpack,代碼規范用eslint。既然要重構,那就順手用es6重寫吧。callback也不要了,全換成promise,async、await也用起來,反正怎么爽怎么寫。

問PM瀏覽器最低兼容到哪個版本,PM說兼容公司各個產品所兼容的最低版本就行。和公司各個產品的前端負責人溝通后發現,居然有兼容IE8的,真是我了個fk。

google了一下Webpack+Babel+ES6兼容IE8,果然坑很多。試了好幾篇博客給出的方案,都跑不通。也沒怎么研究具體哪里有問題,因為那些解決方案里面的webpack和babel都是舊版的,跑通了也不高興用。筆者分析了那些博客中提出的幾個關鍵性問題,然后參考webpack和babel最新的官方文檔,總結出一套最新的Webpack4+Babel7+ES6兼容IE8的方案。

ES6兼容IE8需要解決四個問題

語法支持

IE瀏覽器不支持ES6的語法,只在IE10、IE11中支持了部分ES6的API,所以在IE瀏覽器中使用ES6需要把ES6的代碼編譯成ES5才能執行。方法也很簡單,就是用babel-loader。這部分沒什么坑,所以我也就不細說了。給個網站,大家可以自行查看ES5、ES6在各瀏覽器版本中的支持情況

https://kangax.github.io/compat-table/es6/

ES3保留關鍵字

如果在IE8下通過object.propertyName的方式使用ES3中的保留關鍵字(比如default、class、catch),就會報錯

SCRIPT1048: 缺少標識符

webpack有一款loader插件es3ify-loader專門用來處理ES3的關鍵字兼容問題。這個插件的作用就是把這些保留字給你加上引號,使用字符串的形式引用。

// 編譯前function(t) { return t.default; }// 編譯后function(t) { return t["default"]; }

然而,筆者親身實踐后發現,UglifyJS本來就已經提供了對IE瀏覽器的支持,不需要額外引入es3ify-loader。webpack默認的UglifyJS配置不支持ie8,需要手動配下。

{ mode: 'production', optimization: {  minimizer: [   new UglifyJsPlugin({    uglifyOptions: {     ie8: true    }   })  ] }}

執行環境

解決了前面兩個問題只能保證語法上不報錯,但使用ES6中的API(比如Promise)還是會報錯。另外,IE8對ES5的API支持也很差,只支持了少量的API,有些API還只是支持部分功能(比如Object.defineProperty)。所以,要在IE8中完美運行ES6的代碼,不僅需要填充ES6的API,還要填充ES5的API。

babel為此提供了兩種解決方案: @babel/polyfill、@babel/runtime。具體使用方法官方文檔已經寫的很詳細了,筆者就不贅述了。這里糾正墨白同學文中的一個錯誤,就是@babel/polyfill現在已經支持按需加載,準確的說也不能算是錯誤,因為墨白同學在寫這篇文章的時候還不支持按需加載。具體方法我就不細說了,文檔里都有,配置下browserlist和@babel/preset-env的useBuiltsIns屬性就可以了。

我只說下我在實際開發過程中碰到的坑。

雖然@babel/polyfill、@babel/runtime都支持按需加載,但都只能識別出業務代碼中使用到的缺失的API,如果第三方庫有用到這些缺失的API,babel不能識別出來,自然也就不能填充進來。比如regenerator-runtime中用到的Object.create和Array.prototype.forEach。解決辦法是,在入口文件處手動引入缺失的API。

模塊化加載

筆者原來是想用ES6的模塊化加載方案,因為這樣可以利用webpack的tree shaking,移除冗余代碼,使打包出來的文件體積更小。但在IE8下測試發現Object.defineProperty會報錯'Accessors not supported!'。報錯代碼如下

if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported!');

我用@babel/plugin-transform-modules-commonjs轉成commonjs加載就可以把這個坑繞過去,但同時也意味著放棄了tree shaking。

總結

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兼容需求的同學可以把這個插件去掉        '@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')

最后附上文章開頭提到的sdk源碼,筆者已將公司業務相關代碼去除,將通用部分開源。https://github.com/xtTech/dc-sdk-js

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久久在线| 精品国产1区2区| 九九热视频这里只有精品| 精品久久久久久中文字幕一区奶水| 精品免费在线观看| 日韩av手机在线| 欧美成年人网站| 亚洲男人第一av网站| 日韩在线视频网站| 欧美视频中文在线看| 福利一区福利二区微拍刺激| 97国产精品人人爽人人做| 久久乐国产精品| 韩国国内大量揄拍精品视频| 久久久久成人精品| 亚洲成人精品久久| 岛国av在线不卡| 欧美不卡视频一区发布| 97成人超碰免| 8x拔播拔播x8国产精品| 久久久久久久久久久网站| 色婷婷综合久久久久| 中文字幕av一区中文字幕天堂| 国产美女久久精品香蕉69| 日韩中文字幕亚洲| 久久久久99精品久久久久| 欧美猛交免费看| 日韩av免费在线| 色悠悠国产精品| 午夜精品视频在线| 欧美在线xxx| 精品久久久av| 国产中文字幕亚洲| 久久精品欧美视频| 国产日韩欧美影视| 91精品国产免费久久久久久| 国模精品视频一区二区| 欧美成人精品在线| 亚洲精品aⅴ中文字幕乱码| 亚洲视频精品在线| 久久精品视频99| 在线成人激情视频| 日韩视频欧美视频| 久久中文字幕在线视频| 久久久午夜视频| 亚洲日本成人网| 97色在线视频观看| 懂色av影视一区二区三区| 欧洲成人免费视频| 亚洲资源在线看| 日韩欧美在线观看视频| 岛国av一区二区| 欧美肥老妇视频| 色哟哟网站入口亚洲精品| 4438全国亚洲精品在线观看视频| 亚洲一区二区三区视频播放| 亚洲第一网中文字幕| 久久av中文字幕| 久久国产精品久久久久久| 欧美成人午夜剧场免费观看| 国产精品亚洲第一区| 亚洲va欧美va在线观看| 亚洲缚视频在线观看| 成人伊人精品色xxxx视频| 国产精品精品一区二区三区午夜版| 久久亚洲精品国产亚洲老地址| 国产在线拍揄自揄视频不卡99| 5566日本婷婷色中文字幕97| 国产精品美女主播| 成人免费看吃奶视频网站| 91精品久久久久久久| 狠狠色狠狠色综合日日小说| 国产成人精品午夜| 国产精品久久久| 国产精品久久网| 成人午夜在线影院| 成人在线视频网| 精品国产电影一区| 久操成人在线视频| 欧美国产极速在线| 亚洲欧美日韩天堂| 日韩激情av在线免费观看| 欧美一级成年大片在线观看| 狠狠久久五月精品中文字幕| 视频一区视频二区国产精品| 国产精品一区二区三区久久久| 91爱视频在线| 中文字幕日韩视频| 日韩av在线网址| 亚洲精品白浆高清久久久久久| 国内精品400部情侣激情| 日韩欧美国产免费播放| 日韩亚洲精品视频| 国产成人自拍视频在线观看| 伊人激情综合网| 亚洲一区二区福利| 久热99视频在线观看| 中文综合在线观看| 亚洲性猛交xxxxwww| 日韩三级成人av网| 一个人看的www久久| 欧美亚洲在线视频| 亚洲美女性生活视频| 欧美亚洲视频在线看网址| 疯狂蹂躏欧美一区二区精品| 国产精品久久久久久久天堂| 久久久国产精品一区| 久久手机精品视频| 欧美性猛交丰臀xxxxx网站| 国产精品久久久久av| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产欧美日韩专区发布| 亚洲国产婷婷香蕉久久久久久| 91视频免费网站| 97精品国产97久久久久久免费| 国产日韩精品一区二区| 一区二区三区视频观看| 国产精品女人久久久久久| 久久精品一区中文字幕| 亚洲美女福利视频网站| 国产精品久久久久久久久免费看| 精品av在线播放| 精品久久久久久久久久| 欧美国产极速在线| 91久久精品国产91性色| 性色av一区二区咪爱| 一区二区国产精品视频| 精品久久久久久久久久ntr影视| 亚洲春色另类小说| 欧美日韩激情小视频| 国产亚洲一区精品| 亚洲一区二区三区四区在线播放| 久久精品久久久久电影| 亚洲国产女人aaa毛片在线| 日韩专区中文字幕| 成人激情视频在线播放| 最新中文字幕亚洲| 中文字幕精品一区久久久久| 亚洲高清一区二| 亚洲香蕉成人av网站在线观看| 精品成人国产在线观看男人呻吟| 亚洲男人天堂九九视频| 国产欧美va欧美va香蕉在| 精品欧美一区二区三区| 国产精品三级网站| 亚洲经典中文字幕| 欧美一级片在线播放| 91av在线影院| 久热国产精品视频| 精品久久久免费| 日韩一区二区三区在线播放| 成人黄色免费片| 国产精品入口免费视频一| 成人黄色av免费在线观看| 草民午夜欧美限制a级福利片| 久久久国产精品亚洲一区| 国产91成人在在线播放| 日韩精品在线观看一区| 热久久视久久精品18亚洲精品| 26uuu亚洲国产精品| 国内免费久久久久久久久久久| xxav国产精品美女主播| 欧美精品一本久久男人的天堂| 91精品国产九九九久久久亚洲|