使用webpack编译es6代码的方法步骤


Posted in Javascript onApril 28, 2019

前言

团队使用的 webpack 功能很强大,有时候会碰到编译失败的情况,总得找工具的作者解决问题,自己很少去追究原因,感觉对于 webpack 的认知总是一知半解。因此,从本篇文章开始,自己从零开始配置 webpack,认真体验一下配置过程。文章内容过于简单,如果有 webpack 使用经验的人,就不用往下看啦。

版本说明

本文使用的 webpack 的版本为:4.30.0

开始搭建

本文的目的是使用 webpack 完成 es6 的编译,没想到过程过于简单。

安装 node 与 npm 镜像

安装 node
安装 npm 淘宝镜像

安装 webpack 与 webpack-cli

打开或者新建一个项目,使用命令行安装 webpack 与 webpack-cli:

$ cnpm install --save-dev webpack-cli

安装 es6 的编译组件

使用命令行安装 babel-loader:

$ cnpm install --save-dev babel-loader @babel/core @babel/preset-env webpack

创建文件目录

我创建的文件目录如下:

webpack-es6
 |- /dist
 |- index.html
 |- /src
 |- index.js

定义打包的入口与出口

项目目录下新建 webpack.config.js 文件,并按照文件目录配置打包的入口和出口:

const path = require('path');
module.exports = {
 entry: './src/index.js', // 定义入口 js ,也就是编译前的 js
 output:{
  filename:'index.js', // 定义打包输出的 js 的文件名
  path:path.resolve(__dirname,'dist') // 输出 js 的目录
 }
};

添加 js 文件的处理规则

在 webpack.config.js 文件中添加 js 文件的处理规则:

const path = require('path');
module.exports = {
 entry: './src/index.js', 
 output:{
  filename:'index.js',
  path:path.resolve(__dirname,'dist')
 },
 // 以下代码为新添加代码
 module:{
  rules:[
   {
    test: /\.js$/, // 匹配所有 js 文件
    loader: 'babel-loader' // 使用 babel-loader 处理 js 文件
   },
  ]
 },
};

添加 npm 脚本

在 package.json 文件中添加 npm 脚本:

{
 //... 省略代码
 "scripts": {
  "test": "echo \"Error: no test specified\" && exit 1",
  "build": "webpack" // 添加此行,使用 build 命令代替 npx 命令
 },
 //... 省略代码
 }

配置完成

以上就完成了 webpack 打包 es6 的配置,此时的文件目录如下:

webpack-es6
 |- node_modules
 |- /dist
  |- index.html
 |- /src
  |- index.js
 |- package.json
 |- package-lock.json
 |- webpack.config.js

添加代码

接下来我们添加代码测试配置是否成功。

文件 ./src/index.js 添加代码:

class Class{
 constructor() {
 this.str = 'success';
 }
 appendToBody(){
 const p = document.createElement('p');
 p.innerHTML = this.str;
 document.body.appendChild(p);
 }
}
const obj = new Class();
obj.appendToBody();

文件 ./dist/index.html 添加代码:

</html>
<body></body>
<script src="./index.js"></script>
</html>

编译程序

运行命令行

$ npm run build

打开 index.html ,如果页面中有 success ,则说明 es6 编译完成。

总结

没想到 webpack 编译 es6 配置如此简单,下一步使用 webpack 编译 postcss 。

参考链接

webpack 中文网:www.webpackjs.com/

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery 学习笔记 element属性控制
Jul 23 Javascript
通过jquery的$.getJSON做一个跨域ajax请求试验
May 03 Javascript
Node.js和MongoDB实现简单日志分析系统
Apr 25 Javascript
JS把内容动态插入到DIV的实现方法
Jul 19 Javascript
浅谈javascript的闭包
Jan 23 Javascript
获取当前按钮或者html的ID名称实例(推荐)
Jun 23 Javascript
页面点击小红心js实现代码
May 26 Javascript
angular中两种表单的区别(响应式和模板驱动表单)
Dec 06 Javascript
HTML+JS实现“代码雨”效果源码(黑客帝国文字下落效果)
Mar 17 Javascript
Vue 样式切换及三元判断样式关联操作
Aug 09 Javascript
js观察者模式的弹幕案例
Nov 23 Javascript
详解JavaScript中分解数字的三种方法
Jan 05 Javascript
使用异步组件优化Vue应用程序的性能
Apr 28 #Javascript
详解微信小程序获取当前时间及日期的方法
Apr 28 #Javascript
vue自定义js图片碎片轮播图切换效果的实现代码
Apr 28 #Javascript
如何在微信小程序里面退出小程序的方法
Apr 28 #Javascript
vue实现移动端轻量日期组件不依赖第三方库的方法
Apr 28 #Javascript
详解小程序退出页面时清除定时器
Apr 28 #Javascript
详解在Javascript中进行面向切面编程
Apr 28 #Javascript
You might like
用PHP将数据导入到Foxmail
2006/10/09 PHP
php 来访国内外IP判断代码并实现页面跳转
2009/12/18 PHP
PHP flock 文件锁详细介绍
2012/12/29 PHP
Php output buffering缓存及程序缓存深入解析
2013/07/15 PHP
详解WordPress中过滤链接与过滤SQL语句的方法
2015/12/18 PHP
全新Mac配置PHP开发环境教程
2016/02/03 PHP
php根据数据id自动生成编号的实现方法
2016/10/16 PHP
PHPUnit测试私有属性和方法功能示例
2018/06/12 PHP
使用PHPExcel导出Excel表
2018/09/08 PHP
Thinkphp5+Redis实现商品秒杀代码实例讲解
2020/12/29 PHP
自己做的模拟模态对话框实现代码
2012/05/23 Javascript
获取元素距离浏览器周边的位置的方法getBoundingClientRect
2013/04/17 Javascript
js判断手机端(Android手机还是iPhone手机)
2015/07/22 Javascript
轻松实现JavaScript图片切换
2016/01/12 Javascript
百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系之间的转换
2016/02/19 Javascript
浅谈JavaScript 执行环境、作用域及垃圾回收
2016/05/31 Javascript
AngularJS 模块详解及简单实例
2016/07/28 Javascript
Angular中ng-repeat与ul li的多层嵌套重复问题
2017/07/24 Javascript
微信小程序之页面跳转和参数传递的实现
2017/09/29 Javascript
Webpack devServer中的 proxy 实现跨域的解决
2018/06/15 Javascript
Python中常见的异常总结
2018/02/20 Python
利用Python代码实现数据可视化的5种方法详解
2018/03/25 Python
python生成不重复随机数和对list乱序的解决方法
2018/04/09 Python
Django Web开发中django-debug-toolbar的配置以及使用
2018/05/06 Python
Python实现获取nginx服务器ip及流量统计信息功能示例
2018/05/18 Python
Python实现socket非阻塞通讯功能示例
2019/11/06 Python
使用Pytorch搭建模型的步骤
2020/11/16 Python
Python命令行参数argv和argparse该如何使用
2021/02/08 Python
时尚的CSS3进度条效果
2012/02/22 HTML / CSS
销售员岗位职责范本
2014/02/03 职场文书
初三学习计划书范文
2014/04/30 职场文书
法人代表证明书
2014/09/18 职场文书
教师年终个人总结
2015/02/11 职场文书
春节慰问信范文
2015/02/15 职场文书
Python实现打乒乓小游戏
2021/09/25 Python
Vue2.0搭建脚手架
2022/03/13 Vue.js