使用webpack编译es6代码的方法步骤
作者:NingBo 发布时间:2024-07-22 06:07:07
前言
团队使用的 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/
来源:https://juejin.im/post/5cbec7815188250a9062dd18


猜你喜欢
- 本文实例讲述了JS仿iGoogle自定义首页模块拖拽特效的方法。分享给大家供大家参考。具体实现方法如下:<!DOCTYPE html
- Like中文解释为喜欢的意思,但当应用于MySQL数据库中,Like则是一种语句,用于模糊查询,主要是针对字符型字段的,在一个字符型字段列中
- 我们在使用Golang时,不可避免会遇到异常情况的处理,与Java、Python等语言不同的是,Go中并没有try...catch...这样
- 相信大家在微信上一定被上面的这段话刷过屏,群发消息应该算是微信上流传最广的找到删除好友的方法了。但群发消息不仅仅会把通讯录里面所有的好友骚扰
- 前言??在vue项目中我们常常需要用到computed和watch,那么我们究竟在什么场景下使用computed和watch呢?他们之间又有
- 在Apache和FastCGI上使用Django,你需要安装和配置Apache,并且安装mod_fastcgi。 请参见Apache和mod
- 自带库一、datetimedatetime是Python处理日期和时间的标准库。1、获取当前日期和时间>>> from d
- 大家在使用python的过程中,应该在敲代码的时候经常遇到str内置函数,为了防止大家搞混,本文整理归纳了str内置函数。1字符串查找类:f
- Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能。Git有很多优势,其中之一就是远程操作非常简便。本文详细介绍5个Git
- 具体代码如下所示:package mainimport ( "bufio" "io&q
- SQL JOIN 连接SQL JOIN 子句用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。最常见的 JOIN 类型:SQL
- 设计一个算法,将URL转换成5部分,分别是:schema、netloc、path、query_params、fragment。问题URL的中
- Python tcp socket编程详解初学脚本语言Python,测试可用的tcp通讯程序:服务器:#!/usr/bin/env pyth
- paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。paramiko支持Lin
- 简单展示如何利用python中的pandas库创建、读取、修改CSV数据文件1 写入CSV文件import numpy as npimpor
- 一、软件准备:以下均为截止2005-4-20的最新正式版本PHP(5.1.2):http://www.php.netMySQL(5.0.19
- 如下所示:#!/usr/bin/env python#coding: utf8import getpassdb = {}def newUse
- 在进行小数计算的时候使用float,经常会出现小数位不精确的情况。在python编程中,推荐使用decimal来完成小数位的精度计算。dec
- 所以以 create_time datetime default now() 的形式设置默认值是不可能的。 代替的方案是使用TIMESTAM
- 1.简介: java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包。 它包括两个类:Pattern和Ma