使用webpack編譯es6代碼的方法步驟
前言
團(tuán)隊(duì)使用的 webpack 功能很強(qiáng)大,有時(shí)候會(huì)碰到編譯失敗的情況,總得找工具的作者解決問題,自己很少去追究原因,感覺對于 webpack 的認(rèn)知總是一知半解。因此,從本篇文章開始,自己從零開始配置 webpack,認(rèn)真體驗(yàn)一下配置過程。文章內(nèi)容過于簡單,如果有 webpack 使用經(jīng)驗(yàn)的人,就不用往下看啦。
版本說明
本文使用的 webpack 的版本為:4.30.0
開始搭建
本文的目的是使用 webpack 完成 es6 的編譯,沒想到過程過于簡單。
安裝 node 與 npm 鏡像
安裝 webpack 與 webpack-cli
打開或者新建一個(gè)項(xiàng)目,使用命令行安裝 webpack 與 webpack-cli:
$ cnpm install --save-dev webpack-cli
安裝 es6 的編譯組件
使用命令行安裝 babel-loader:
$ cnpm install --save-dev babel-loader @babel/core @babel/preset-env webpack
創(chuàng)建文件目錄
我創(chuàng)建的文件目錄如下:
webpack-es6 |- /dist |- index.html |- /src |- index.js
定義打包的入口與出口
項(xiàng)目目錄下新建 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 文件的處理規(guī)則
在 webpack.config.js 文件中添加 js 文件的處理規(guī)則:
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 的配置,此時(shí)的文件目錄如下:
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>
編譯程序
運(yùn)行命令行
$ npm run build
打開 index.html ,如果頁面中有 success ,則說明 es6 編譯完成。
總結(jié)
沒想到 webpack 編譯 es6 配置如此簡單,下一步使用 webpack 編譯 postcss 。
參考鏈接
webpack 中文網(wǎng):www.webpackjs.com/
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS中定時(shí)器的使用及頁面切換時(shí)定時(shí)器無法清除問題的解決辦法
定時(shí)器相信大家應(yīng)該都不陌生,下面這篇文章主要給大家介紹了關(guān)于JS中定時(shí)器的使用及頁面切換時(shí)定時(shí)器無法清除問題的解決辦法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
JavaScript Event學(xué)習(xí)第八章 事件的順序
在第一章中我提到一個(gè)初次看起來可能不是那么好理解的是一個(gè)問題:“如果一個(gè)元素和他的父元素對于同樣的事件都有事件處理程序,那么哪個(gè)會(huì)首先執(zhí)行呢?”毫無疑問,看是什么瀏覽器。2010-02-02
javascript如何動(dòng)態(tài)加載表格與動(dòng)態(tài)添加表格行
在某些時(shí)候需要?jiǎng)討B(tài)加載表格與動(dòng)態(tài)添加表格行,在接下來的文章中將為大家介紹下javascript是如何做到的,感興趣的朋友不要錯(cuò)過2013-11-11
圖片自定義滾動(dòng)條3.0(Duma“自動(dòng)渲染版”,也許世間萬物都會(huì)變,但是真摯的愛,卻永遠(yuǎn)留存在心中?。?/div> 2009-07-07
JavaScript實(shí)現(xiàn)的購物車效果可以運(yùn)用在好多地方
JavaScript實(shí)現(xiàn)的購物車效果,當(dāng)然這個(gè)效果可以運(yùn)用在好多地方,比如好友的選擇,人力資源模塊等等,需要的朋友可以參考下2014-05-05最新評論

