webpack3实战(3)打包有es6、es7语法的js代码

前注:

文档全文请查看 根目录的文档说明

如果可以,请给本项目加【Star】和【Fork】持续关注。

有疑义请点击这里,发【Issues】。

实战项目示例目录

1、需求列表

1、html文件引入的js文件,需要使用es6、es7的语法;

2、使用的语法里,除了常规的es6语法外,还包括例如Promise、async等特殊特性,要求可以转换。

注:babel默认只转js语法,而不转换新的API,例如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比如Object.assign)。所以我们必须引入额外的babel插件来解决这个问题

2、步骤

安装依赖

npm install

执行打包命令:

npm run test

查看打包后效果:

index.html

3、说明

引入的模块就不说了,如果不想引入全部,而是想引入部分,请参照【5、Loader】里的【babel-loader】文档。

关于loader的写法很简单,唯一区别是在哪里设置babel的配置。


第一种办法:

写在 .babelrc文件里,就像我们一般使用babel那样,文件内容如下。

{
  "presets": [
    "babel-preset-env"
  ],
  "plugins": [
    "transform-runtime"
  ]
}

此时loader写法如下(以上以下代码已省略):

module: {
    // loader放在rules这个数组里面
    rules: [
        {
            test: /\.js$/,
            // 这里表示忽略的文件夹,正则语法
            exclude: /node_modules/,
            loader: 'babel-loader'
        }
    ]
}

第二种写法,不使用 .babelrc 文件,而是直接写在babel-loader里。

此时loader写法如下(以上以下代码已省略):

module: {
    // loader放在rules这个数组里面
    rules: [
        {
            test: /\.js$/,
            exclude: /node_modules/,
            loader: 'babel-loader',
            options: {
                presets: ['babel-preset-env'],
                plugins: ['transform-runtime']
            }
        }
    ]
}

第三种写法,和第二种写法类似,只不过细节有所区别。

module: {
    // loader放在rules这个数组里面
    rules: [
        {
            test: /\.js$/,
            exclude: /node_modules/,
            // 区别在这里
            use: {
                loader: 'babel-loader',
                options: {
                    presets: ['babel-preset-env'],
                    plugins: ['transform-runtime']
                }
            }
        }
    ]
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值