使用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 插件模板 制作jquery插件的朋友可以参考下
Mar 17 Javascript
js模拟C#中List的简单实例
Mar 06 Javascript
jQuery实现仿百度帖吧头部固定导航效果
Aug 07 Javascript
jQuery实现简单的列表式导航菜单效果代码
Aug 31 Javascript
jquery实现可自动判断位置的弹出层效果代码
Oct 12 Javascript
使用伪命名空间封装保护独自创建的对象方法
Aug 04 Javascript
浅析如何利用angular结合translate为项目实现国际化
Dec 08 Javascript
jquery实现手机端单店铺购物车结算删除功能
Feb 22 Javascript
移动端滑动切换组件封装 vue-swiper-router实例详解
Nov 25 Javascript
jQuery 移除事件的方法
Jun 20 jQuery
javascript读取本地文件和目录方法详解
Aug 06 Javascript
vue.js+element 默认提示中英文操作
Nov 11 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
网站当前的在线人数
2006/10/09 PHP
php使用标签替换的方式生成静态页面
2015/05/21 PHP
javascript下4个跨浏览器必备的函数
2010/03/07 Javascript
js页面跳转的常用方法整理
2013/10/18 Javascript
JavaScript面向对象编程入门教程
2014/04/16 Javascript
ie 7/8不支持trim的属性的解决方案
2014/05/23 Javascript
JavaScript中数组成员的添加、删除介绍
2014/12/30 Javascript
JS实现CheckBox复选框全选全不选功能
2015/05/06 Javascript
怎么引入(调用)一个JS文件
2016/05/26 Javascript
第一次接触神奇的Bootstrap导航条
2016/08/09 Javascript
Javascript6中字符串的四个新用法分享
2016/09/11 Javascript
javascript滚轮控制模拟滚动条
2016/10/19 Javascript
JS实现控制图片显示大小的方法【图片等比例缩放功能】
2017/02/18 Javascript
jquery中each循环的简单回滚操作
2017/05/05 jQuery
Angular2学习教程之TemplateRef和ViewContainerRef详解
2017/05/25 Javascript
JS基于对象的链表实现与使用方法示例
2019/01/31 Javascript
我所理解的JavaScript中的this指向
2020/09/04 Javascript
python使用scrapy解析js示例
2014/01/23 Python
python实现手机通讯录搜索功能
2018/02/22 Python
用Anaconda安装本地python包的方法及路径问题(图文)
2019/07/16 Python
django+echart数据动态显示的例子
2019/08/12 Python
Python 函数用法简单示例【定义、参数、返回值、函数嵌套】
2019/09/20 Python
Python实现获取当前目录下文件名代码详解
2020/03/10 Python
Python之变量类型和if判断方式
2020/05/05 Python
IntelliJ 中配置 Anaconda的过程图解
2020/06/01 Python
有750多个顶级品牌的瑞士时尚在线:ABOUT YOU
2017/01/04 全球购物
中国跨境电子商务网站:NewFrog
2018/03/10 全球购物
电气专业推荐信范文
2013/11/18 职场文书
初中高效课堂实施方案
2014/02/26 职场文书
《周恩来的四个昼夜》观后思想汇报范文两篇
2014/09/10 职场文书
2014年帮扶工作总结
2014/11/26 职场文书
齐云山导游词
2015/02/06 职场文书
护士求职简历自我评价
2015/03/10 职场文书
积极心理学课程心得体会
2016/01/22 职场文书
《爬天都峰》教学反思
2016/02/23 职场文书
会议主持词通用版
2019/04/02 职场文书