一、Webpack是什么?
Webpack 是一个打包模块化 JavaScript 的工具,在 Webpack 里一切文件皆模块,通过 Loader 转换文件,通过 Plugin 注入钩子,最后输出由多个模块组合成的文件。Webpack 专注于构建模块化项目。
一切文件:JavaScript、CSS、SCSS、图片、模板,在 Webpack 眼中都是一个个模块,这样的好处是能清晰的描述出各个模块之间的依赖关系,以方便 Webpack 对模块进行组合和打包。 经过 Webpack 的处理,最终会输出浏览器能使用的静态资源。
二、Webpack 的优点?
专注于处理模块化的项目,能做到开箱即用一步到位;
通过 Plugin 扩展,完整好用又不失灵活;
使用场景不仅限于 Web 开发;
社区庞大活跃,经常引入紧跟时代发展的新特性,能为大多数场景找到已有的开源扩展;
良好的开发体验
三、安装
全局安装:npm install -g webpack
npm install -g webpack-cli
项目依赖:npm install --save-dev webpack
npm install --save-dev webpack-cli
四、Webpack 基本配置
需要在项目的根目录下创建一个文件 webpack.config.js
1、基本配置–入口
入口起点(entry point)指示 webpack 应该使用 哪个模块,来作为构建其内部依赖图的开始
entry:string | array | object
string: 是一个字符串形式的相对路径,找到某一个具体的文件
array:['string','string'];
object:{
a: 'string',
b:'string'
}
1、单个入口
entry:string | array
2、对象形式,配置多个路径
entry:{
app:'./路径',
other:'./路径',
some:'./路径'
}
说明:entry 中的入口文件打包时会打包相关的有依赖关系的对应文件
2、基本配置-出口
output 属性 告诉 webpack 在哪里输出它所创建的 bundles
output:{
// 存储路径:要求是绝对路径
path:path.resolve(__dirname,'dist'),
filename:'my-first-webpack.bundle.js'
filename:'[name].js'
}
1、单出口
{
filename:'app.js'
}
2、多出口
[name]叫占位符,name 会自动找 entry 对象中的键名
{
filename:[name].js
}
3、基本配置-loaders
loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)。loader 可以将所有类型的文件转换为 webpack 能够处理的有效模块,然后你就可以利用 webpack 的打包能力,对它们进行处理
module:{
rules:[
// es6->es5
{
test:/\.js$/,
use:{
loader:'babel-loader'
options:{
presets:['@babel/preset-env']
}
},
// include 包含作用,限定转换的范围
include:path.resolve(__dirname,'src')
// exclude 是排除作用
exclude:[path.resolve(__dirname, 'src')]
}
]
}
4、基本配置-pugins
webpack插件(自动打开浏览器、热更新等)
1.HtmlWebpackPlugin插件:自动创建html页面
安装:
npm install -- save-dev html-webpack-plugin
配置:
1.引入到webpack.config.js中
2.在plugins中配置
plugins:[
new HtmlWebpackPlugin({
template:'./index.html'
})
]
2、2.ExtractTextWebpackPlugin插件:提取css到单独文件
安装:
npm install --save-dev extract-text-webpack-plugin@next
配置:
{
test: /\.css$/,
use:ExtractTextPlugin.extract({
fallback: "style-loader",
use: "css-loader"
})
}
plugins:[
new ExtractTextPlugin("styles.css")
]