创建项目文件夹
用npm的包管理工具管理起来 npm init -y
其中-y
是yes
,表示跳过提问阶段直接生成package
文件
如果创建的项目名称是中文则不能加-y
,需要回答问题
创建dist
文件夹, 是项目打包之后输出的文件夹
创建src
文件夹
创建/src/index.html
这是项目的首页
创建/src/main.js
项目的入口文件
然后 webpack .\src\main.js -o .\dist\bundle.js
命令
因为webpack
打包命令每次都要输入十分麻烦,所以需要安装 webpack-dev-server
:
cnpm i webpack-dev-server -D
,同时根据提示需要同时在项目本地中安装webpack
cnpm i webpack -D
然后在项目的根目录中新建一个 webpack.config.js
const path = require('path')
module.exports = {
entry: path.join(__dirname, './src/main.js'),// 入口,表示,要使用 webpack 打包哪个文件
output: { // 输出文件相关的配置
path: path.join(__dirname, './dist'), // 指定 打包好的文件,输出到哪个目录中去
filename: 'bundle.js' // 这是指定 输出的文件的名称
}
这里添加上项目的输入和输入文件,这样只需要webpack
命令即可打包
为了用webpack-dev-server
,需要在package.json
中添加脚本:
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"dev": "webpack-dev-server --open --port 3000 --contentBase src --hot",
}
然后使用npm run dev
webpack-dev-server
会帮我们托管资源此时script
标签中../dist/bundle.js
路径是错误的,正确的应该是/bundle.js
这时候我们使用html-webpack-plugin
插件解决这个问题
可以在内存中根据指定的模板页面生成一份内存中的首页,同时自动把打包好的bundle注入到页面的底部,
同时如果要配置插件,需要在导出的对象中挂在一个plugins节点
const htmlWebpackPlugin = require('html-webpack-plugin')
module.exports = {
plugins: [
new htmlWebpackPlugin({
template: path.join(__dirname, './src/index.html'), //制定模板文件路径
filename: 'index.html' //指定生成页面的名称
})
],
}
添加css,在/css中创建css文件
在main.js
中添加
import './css/index.css'
这样会报错,因为webpack处理不了非JS文件
安装style-loader
和css-loader
------>cnpm i style-loader css-loader -D
在webpack中添加module,配置所有第三方loader模块
module中的rules是第三方模块的匹配规则
module:{
rules: [
{test: /\.css$/, use:['style-loader', 'css-loader']}, //配置.css文件的第三方loader规则
{test: /\.less$/, use:['style-loader', 'css-loader' ,'less-loader']}, //配置处理.less文件的第三方loader规则
{test: /\.scss/, use:['style-loader', 'css-loader', 'less-loader']}
]
}
其中use中的使用顺序是从右往左