webpack學(xué)習(xí)第九步——babel編譯es6及react

es6 在低版本瀏覽器程序報錯

安裝相關(guān)babel

// JS和loader打通
npm install babel-loader @babel/core -D
// 將es6轉(zhuǎn)化為es5
npm install @babel/preset-env -D
  • index.js用es6語法
const arr = [
    new Promise(() => {}),
    new Promise(() => {})
]

arr.map(item => console.log(item))
  • 修改webpack.config.js
module: {
    rules: [{
        test: /\.(jpg|png|gif)$/,
        use: {
            loader: "url-loader",
            options: {
                name: '[name]_[hash].[ext]',
                outputPath: 'images/',
                limit: 2048
            }
        }
    },{
        test: /\.css$/,
        use: [
            'style-loader',
            'css-loader',
            'postcss-loader'
        ]
    },{
    // 對js文件使用babel-loader 及 @babel/preset-env
        test: /\.js$/,
        exclude: /node_modules/,
        loader: 'babel-loader',
        options: {
            presets: ["@babel/preset-env"]
        }
    }]
}
  • 因為webpack-dev-server會不會打包build文件而是放到內(nèi)存杜秸,不便于我們觀察打包后的文件,所以修改package.json文件欠橘,將命令修改為普通打包,webpack.config.js中dev-tools也修改為"none"便于觀察打包后的文件
"scripts": {
    "start": "webpack",
},
  • 打包后的文件自動將es6編譯成了es5

babel-polyfill

  • polyfill 補充低版本瀏覽器不存在的一些內(nèi)容
  • 安裝
npm install @babel/polyfill -D
  • 使用 @babel/polyfill
// 引入polyfill
import "@babel/polyfill"
const arr = [
    new Promise(() => {}),
    new Promise(() => {})
]

arr.map(item => console.log(item))
  • 引入了polyfill會使打包的文件變大
  • 修改webpack.config.js,配置屬性财著,按需引入
module: {
    rules: [{
        test: /\.(jpg|png|gif)$/,
        use: {
            loader: "url-loader",
            options: {
                name: '[name]_[hash].[ext]',
                outputPath: 'images/',
                limit: 2048
            }
        }
    },{
        test: /\.css$/,
        use: [
            'style-loader',
            'css-loader',
            'postcss-loader'
        ]
    },{
        test: /\.js$/,
        exclude: /node_modules/,
        loader: 'babel-loader',
        options: {
            presets: [["@babel/preset-env",{
                // polyfill只添加業(yè)務(wù)代碼用到的特性
                useBuiltIns: 'usage'
            }]]
        }
    }]
},

配置其他屬性

  • 修改webpack.config.js
{
    test: /\.js$/,
    exclude: /node_modules/,
    loader: 'babel-loader',
    options: {
        presets: [["@babel/preset-env",{
            useBuiltIns: 'usage',
            targets: {
                // 大于67版本的chrome上
                chrome: '67',
            }
        }]]
    }
}
  • chorme67以上支持es6語法跺撼,因此打包出來也是es6語法

polyfill 全局污染問題解決

  • 類庫灭贷、ui組件庫使用import "@babel/polyfill"會造成全局污染,因為polly-fill 在window上綁定了一些全局變量削茁,而plugin-transform-runtime則使用閉包的形式
npm install @babel/plugin-transform-runtime -D
npm install @babel/runtime -D 
npm install @babel/runtime-corejs2 -D

  • 修改webpack.config.js
{
    test: /\.js$/,
    exclude: /node_modules/,
    loader: 'babel-loader',
    options: {
        // presets: [["@babel/preset-env",{
        //     useBuiltIns: 'usage',
        //     targets: {
        //         chrome: '67',
        //     }
        // }]]
        
        // 使用plugin-transform-runtime
        plugins: [["@babel/plugin-transform-runtime",{
            "corejs": 2,
            "helpers": true,
            "regenerator": true,
            "useESModules": false
        }]]
    }
}
  • index.js不需要去import polyfill
// import "@babel/polyfill"
const arr = [
    new Promise(() => {}),
    new Promise(() => {})
]

arr.map(item => console.log(item))
  • 打包后的文件

babelrc文件

  • babel相關(guān)的配置都可以放到單獨的.babelrc文件中

  • 修改webpack.config.js

{
    test: /\.js$/,
    exclude: /node_modules/,
    loader: 'babel-loader',
}
  • 將options的內(nèi)容都放置到.babelrc文件
//.babelrc文件
{
  "plugins": [["@babel/plugin-transform-runtime",{
    "corejs": 2,
    "helpers": true,
    "regenerator": true,
    "useESModules": false
  }]]
}

打包react文件

  • 先安裝react相關(guān)庫
npm install react react-dom -D
  • 安裝react的babel,用來解析jsx語法
npm install @babel/preset-react -D
  • 修改.babelrc文件
{
  "presets": [
    [
      "@babel/preset-env",{
        "targets": {
          "chrome": "67"
        },
        "useBuiltIns": "usage"
      }
    ],
    // 增加react的babel
    "@babel/preset-react"
  ]
}
  • 修改index.js
import "@babel/polyfill"
import React,{ Component } from 'react'
import ReactDom from 'react-dom'
class App extends Component {
    render() {
        return <div>hello world</div>
    }
}

ReactDom.render(<App/>,document.getElementById('root'))
  • 打包出來的文件
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末粟害,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子颤芬,更是在濱河造成了極大的恐慌悲幅,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件站蝠,死亡現(xiàn)場離奇詭異汰具,居然都是意外死亡,警方通過查閱死者的電腦和手機菱魔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門留荔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人澜倦,你說我怎么就攤上這事聚蝶。” “怎么了藻治?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵碘勉,是天一觀的道長。 經(jīng)常有香客問我桩卵,道長验靡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任雏节,我火速辦了婚禮胜嗓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘钩乍。我一直安慰自己辞州,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布件蚕。 她就那樣靜靜地躺著孙技,像睡著了一般产禾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上牵啦,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天亚情,我揣著相機與錄音,去河邊找鬼哈雏。 笑死楞件,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的裳瘪。 我是一名探鬼主播土浸,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼彭羹!你這毒婦竟也來了黄伊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤派殷,失蹤者是張志新(化名)和其女友劉穎还最,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毡惜,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡拓轻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了经伙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扶叉。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖帕膜,靈堂內(nèi)的尸體忽然破棺而出枣氧,到底是詐尸還是另有隱情,我是刑警寧澤泳叠,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布作瞄,位于F島的核電站,受9級特大地震影響危纫,放射性物質(zhì)發(fā)生泄漏宗挥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一种蝶、第九天 我趴在偏房一處隱蔽的房頂上張望契耿。 院中可真熱鬧,春花似錦螃征、人聲如沸搪桂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽踢械。三九已至酗电,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間内列,已是汗流浹背撵术。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留话瞧,地道東北人嫩与。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像交排,于是被迫代替她去往敵國和親划滋。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容