webpack实战6之js代码处理

注意:

本文假设你有webpack 的基础认识。

本文的目的是将es6代码转成es5,和使用jslint检查

项目目录

1.jpg

开始实战

创建一个目录<code>webpack-demo6</code>,并安装<code>wbepack</code>。

  mkdir webpack-demo6 && cd webpack-demo6
  npm init -y
  npm install --save-dev webpack

安装 <code>jshint</code>,<code>jshint-loader</code>,<code>babel-core</code>,<code>babel-loader</code>,<code>babel-preset-env</code>

npm install --save-dev jshint jshint-loader babel-core babel-loader babel-preset-env

新建<code>index.html</code>文件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>webpack 实战</title>
</head>
<body>
    <script src="./dist/bundle.js"></script>
</body>
</html>

新建<code>index.js</code>文件

  class Person {
    constructor(age, name) {
      this.age = age;
      this.name = name;
    }
    dance() {
        document.body.innerHTML = 'I Can Dance!'
    }
}

let p = new Person(25, 'noshower');
p.dance();

这里我们使用es6的构造函数写法。然后使用babel转成es5语法。

新建<code>.jshintrc</code>文件

  {
// 例如
"camelcase": true,
//jslint的错误信息在默认情况下会显示为warning(警告)类信息
//将emitErrors参数设置为true可使错误显示为error(错误)类信息
"emitErrors": false,
//jshint默认情况下不会打断webpack编译
//如果你想在jshint出现错误时,立刻停止编译
//请设置failOnHint参数为true
"failOnHint": false,
// 告诉jshint,我在使用es6语法
"esversion": 6
}

.jshintrc 是jshint的配置文件,不需要指定,jshint会自动引用它。

新建<code>webpack.config.js</code>文件

const path = require('path');

module.exports = {
entry: './index.js',
output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
},
module: {
    rules: [
        {
            test: /\.js$/,
            enforce: 'pre',
            exclude: /node_modules/,
            use: [
                {
                    loader: 'jshint-loader'
                }
            ]
        }, {
            test: /\.js$/,
            use: [
                {
                    loader: 'babel-loader',
                    options: {
                        presets: ['env']
                    }
                }
            ],
            exclude: /node_modules/
        }
    ]
}
}

进行打包

webpack --config webpack.config.js

结果显示:

1.jpg

jshint告诉我们 index.js文件第7行末尾少了个分号。

于是,我们将分号加上,重新打包。结果显示:

1.jpg

现在结果正常了。

然后,我们打开bundle.js文件,我们可以看到,es6语法被转成了es5语法了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,343评论 4 31
  • 最近在学习 Webpack,网上大多数入门教程都是基于 Webpack 1.x 版本的,我学习 Webpack 的...
    My_Oh_My阅读 8,224评论 40 247
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,273评论 7 35
  • webpack 介绍 webpack 是什么 为什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert阅读 6,540评论 2 71
  • “Tony,你有两笔订单的货款还没有收回,已经超期未付了,烦请这周和客户确认一下,谢谢!” “客户这两天就会付了,...
    June88阅读 193评论 1 2