摘要:基礎配置如下設置轉碼規(guī)則和插件字段設定轉碼規(guī)則,官方提供以下的規(guī)則集,按需安裝。結合許多工具需要進行前置轉碼,如和在項目根目錄下,新建一個配置文件,在其中加入字段。在之中,加入相應的腳本部分參考到底該如何配置
babel
標簽(空格分隔): babel
babelBabel是一個廣泛使用的轉碼器,可以將ES6代碼轉為ES5代碼,從而在現有環(huán)境執(zhí)行。
Babel 會在正在被轉錄的文件的當前目錄中查找一個 .babelrc 文件。 如果不存在,它會遍歷目錄樹,直到找到一個 .babelrc 文件,或一個 package.json 文件中有 "babel": {}
babel6將babel全家桶拆分成了許多不同的模塊(rc是run command的縮寫)
依賴babel-loader:使用es6或加載模塊時,對es6代碼進行預處理,轉為es5語法。presets
babel-core:允許我們去調用babel的api,可以將js代碼分析成ast(抽象語法樹),方便各個插件分析語法進行相應的處理.
babel-preset-env:推薦preset,比如es2015,es2016,es2017,latest,env(包含前面全部)
babel-polyfill:它效仿一個完整的ES2015+環(huán)境,使得我們能夠使用新的內置對象比如 Promise,比如 Array.prototype.includes 和生成器函數(提供給你使用 regenerator 插件)。為了達到這一點, polyfill 添加到了全局范圍,就像原生類型比如 String 一樣。
babel-runtime babel-plugin-transform-runtime:這個插件能自動為項目引入polyfill和helpers
babel5會默認轉譯ES6和jsx語法,babel6轉譯的語法都要在perset中配置,preset簡單說就是一系列plugin包的使用。
預設就是一系列插件的集合,把之前的參數保存為一個預設,下次就能直接使用。
基礎配置如下:(設置轉碼規(guī)則和插件)
{ "presets": [], "plugins": [] }
presets字段設定轉碼規(guī)則,官方提供以下的規(guī)則集,按需安裝。
可以看到提案在進入stage3階段時就已經在一些環(huán)境被實現,在stage2階段有babel的實現。
# ES2015轉碼規(guī)則 babel-preset-es2015 # react轉碼規(guī)則 babel-preset-react # ES7不同階段語法提案的轉碼規(guī)則(共有4個階段) babel-preset-stage-0 babel-preset-stage-1: draft - 必須包含2個實驗性的具體實現,其中一個可以是用轉譯器實現的,例如Babel。 babel-preset-stage-2: candidate - 至少要有2個符合規(guī)范的具體實現。 babel-preset-stage-3
配置:
{ "presets": [ "es2015", "stage-2" ], "plugins": [] }
babel-preset-env
此段內容來自于babel到底該如何配置?
上面這些preset官方現在都已經不推薦了,官方唯一推薦preset:babel-preset-env
這款preset能靈活決定加載哪些插件和polyfill
// cnpm install -D babel-preset -env { "presets": [ ["env", { "targets": { //指定要轉譯到哪個環(huán)境 //瀏覽器環(huán)境 "browsers": ["last 2 versions", "safari >= 7"], //node環(huán)境 "node": "6.10", //"current" 使用當前版本的node }, //是否將ES6的模塊化語法轉譯成其他類型 //參數:"amd" | "umd" | "systemjs" | "commonjs" | false,默認為"commonjs" "modules": "commonjs", //是否進行debug操作,會在控制臺打印出所有插件中的log,已經插件的版本 "debug": false, //強制開啟某些模塊,默認為[] "include": ["transform-es2015-arrow-functions"], //禁用某些模塊,默認為[] "exclude": ["transform-es2015-for-of"], //是否自動引入polyfill,開啟此選項必須保證已經安裝了babel-polyfill //參數:Boolean,默認為false. "useBuiltIns": false }] ] }
{ "presets": [ ["env", { "modules": false, "targets": { "browsers": ["> 1%", "last 2 versions", "not ie <= 8"] } }], "stage-2" ], "plugins": [ "transform-vue-jsx", "transform-runtime", "syntax-dynamic-import", "transform-es2015-modules-commonjs" ] }plugins
此段內容來自于babel到底該如何配置?
babel中的插件,通過配置不同的插件才能告訴babel,我們的代碼中有哪些是需要轉譯的。
插件官網
{ "plugins": [ ["transform-es2015-arrow-functions", { "spec": true }] ] }
transform-runtime,這個插件能自動為項目引入polyfill和helpers
polyfill作用是用已經存在的語法和api實現一些瀏覽器還沒有實現的api,對瀏覽器的一些缺陷做一些修補。例如Array新增了includes方法,但是低版本的瀏覽器上沒有,就得做兼容處理
transform-runtime這個插件依賴于babel-runtime
babel-runtime由三個部分組成:
core-js
core-js極其強悍,通過ES3實現了大部分的ES5、6、7的polyfill。
regenerator
regenerator來自facebook的一個庫,用于實現 generator functions。
helpers
babel的一些工具函數,這個helpers和使用babel-external-helpers生成的helpers是同一個東西
配置transform-runtime
{ "plugins": [ ["transform-runtime", { "helpers": false, //自動引入helpers "polyfill": false, //自動引入polyfill(core-js提供的polyfill) "regenerator": true, //自動引入regenerator }] ] }
比較transform-runtime與babel-polyfill引入墊片的差異:
使用runtime是按需引入,需要用到哪些polyfill,runtime就自動幫你引入哪些,不需要再手動一個個的去配置plugins,只是引入的polyfill不是全局性的,有些局限性。而且runtime引入的polyfill不會改寫一些實例方法,比如Object和Array原型鏈上的方法,像前面提到的Array.protype.includes。結合ESLint
babel-polyfill就能解決runtime的那些問題,它的墊片是全局的,而且全能,基本上ES6中要用到的polyfill在babel-polyfill中都有,它提供了一個完整的ES6+的環(huán)境。babel官方建議只要不在意babel-polyfill的體積,最好進行全局引入,因為這是最穩(wěn)妥的方式。
一般的建議是開發(fā)一些框架或者庫的時候使用不會污染全局作用域的babel-runtime,而開發(fā)web應用的時候可以全局引入babel-polyfill避免一些不必要的錯誤,而且大型web應用中全局引入babel-polyfill可能還會減少你打包后的文件體積(相比起各個模塊引入重復的polyfill來說)。
許多工具需要Babel進行前置轉碼,如ESLint和Mocha
在項目根目錄下,新建一個配置文件.eslint,在其中加入parser字段。
{ "parser": "babel-eslint", "rules": { ... } }
在package.json之中,加入相應的scripts腳本
"scripts": { "lint": "eslint --ext .js,.vue src", },
部分參考:
babel到底該如何配置?
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/101424.html
摘要:簡單的說就是,新語法編譯器舊語法。說明所以,對于新特性,我們可以通過使用,也可以通過語法轉化來達到兼容。 0x001 polyfill 我們都知道,js總是一直存在著兼容性問題,雖然其他語言也存在著兼容性問題,比如c++、java,但那種兼容性是新特性在舊版本上的不兼容,js則存在著各種奇形怪哉的不兼容。這其中有著非常復雜的歷史和時代的原因,并不加以累述。而解決兼容性問題的方法在以前只...
摘要:進入入口起點后,會找出有哪些模塊和庫是入口起點直接和間接依賴的。用于對模塊的源代碼進行轉換。指定生產還是開發(fā)入口文件打包后的文件名這里需指定一個絕對路徑我們需要的模塊去解析路徑包含一系列的規(guī)則是一個具有屬性的對象。 前文:進擊webpack 4 (基礎篇 一) webpack.config.js基礎配置 webpack 有4大概念 入口(entry) 輸出(output) load...
摘要:不信你命令行里敲個試試敲敲敲當然了想直接運行命令,你需要將添加到系統(tǒng)變量啊。全局安裝相同的,運行命令耐心等待安裝完成后,你的系統(tǒng)變量里就存在命令了,你可以運行下試試。上訴如果有不懂的,歡迎留言。 再一次見面! Light 還是太太太懶了,距離上一篇沒啥營養(yǎng)的文章已經過去好多天。今天為大家介紹介紹 webpack 最基本的概念,以及簡單的配置,讓你能快速得搭建一個可用的 webpack ...
摘要:全文的目的是達成使用進行項目開發(fā),并且以我這個前端菜鳥所見所學來歸納整理。環(huán)境安裝與前期準備我的基礎環(huán)境出的開源的編輯器命令行工具,下一個炒雞好用的神器。只提供組件,對配套技術不做限定,方便用戶與現有技術棧快速整合,降低使用成本。 全文的目的是達成使用amazeui-touch進行項目開發(fā),并且以我這個前端菜鳥所見所學來歸納整理。文章不對詳細內容做講解。 環(huán)境安裝與前期準備 我的基礎環(huán)...
摘要:全文的目的是達成使用進行項目開發(fā),并且以我這個前端菜鳥所見所學來歸納整理。環(huán)境安裝與前期準備我的基礎環(huán)境出的開源的編輯器命令行工具,下一個炒雞好用的神器。只提供組件,對配套技術不做限定,方便用戶與現有技術??焖僬希档褪褂贸杀?。 全文的目的是達成使用amazeui-touch進行項目開發(fā),并且以我這個前端菜鳥所見所學來歸納整理。文章不對詳細內容做講解。 環(huán)境安裝與前期準備 我的基礎環(huán)...
閱讀 893·2021-11-23 09:51
閱讀 1107·2021-11-15 17:57
閱讀 1674·2021-09-22 15:24
閱讀 820·2021-09-07 09:59
閱讀 2234·2019-08-29 15:10
閱讀 1857·2019-08-29 12:47
閱讀 760·2019-08-29 12:30
閱讀 3381·2019-08-26 13:51