概念

打包你的资源,webpack是把项目当作一个整体,通过一个给定的的主文件,webpack将从这个文件开始找到你的项目的所有依赖文件,使用loaders处理它们,最后打包成一个或多个浏览器可识别的js文件
entry
entry: 用来指示webpack的入口文件,它将是整个依赖关系的根。webpack会从它开始帮你找到所有的依赖文件,并完成处理打包
var baseConfig = {
entry: './src/index.js'
}
当我们需要多个入口文件的时候,可以把entry写成一个对象
var baseConfig = {
entry: {
main: './src/index.js'
}
}
output
output: 属性告诉 webpack 在哪里输出它所创建(打包)的 bundles,以及如何命名这些文件。注意,即使入口文件有多个,但是只有一个输出配置。
var path = require('path')
var baseConfig = {
entry: {
main: './src/index.js'
},
output: {
filename: 'main.js',
path: path.resolve(__dirname, 'dist')
}
}
module.exports = baseConfig
在上面的示例中,我们通过 output.filename
和 output.path
属性,来告诉 webpack bundle 的名称,以及我们想要 bundle 生成(emit)到哪里。可能你想要了解在代码最上面导入的 path 模块是什么,它是一个 Node.js 核心模块,用于操作文件路径。
如果你定义的入口文件有多个,那么我们需要使用占位符来确保输出文件的唯一性
output: {
filename: '[name].js',
path: __dirname + '/dist'
}
如今这么少的配置,就能够让你运行一个服务器并在本地使用命令npm start或者npm run build来打包我们的代码进行发布
Loader
loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)。loader 可以将所有类型的文件转换为 webpack 能够处理的有效模块,然后你就可以利用 webpack 的打包能力,对它们进行处理。
var path = require('path')
var baseConfig = {
entry: {
main: './src/index.js'
},
output: {
filename: 'main.js',
path: path.resolve(__dirname, 'dist')
},
module: {
rules: [
{
test: /\.txt$/,
use: 'raw-loader'
}
]
}
}
module.exports = baseConfig
以上配置中,对一个单独的 module 对象定义了 rules 属性,里面包含两个必须属性:test 和 use。
- test 属性,用于标识出应该被对应的 loader 进行转换的某种文件。
- use 属性,表示进行转换时,应该使用哪个 loader。
还有 loader 的一些其他配置
test: 匹配所处理文件的扩展名的正则表达式(必须)
loader: loader的名称(必须)
include/exclude: 手动添加处理的文件 / 屏蔽不需要处理的文件(可选)
query: 为loaders提供额外的设置选项
var baseConfig = {
// ...
module: {
rules: [
{
test: /*匹配文件后缀名的正则*/,
use: [
loader: /*loader名字*/,
query: /*额外配置*/
],
exclude: /node_modules/
}
]
}
}
列举一些常用的 loader
- babel-loader:让下一代的js文件转换成现代浏览器能够支持的JS文件。
注:babel有些复杂,所以大多数都会新建一个.babelrc进行配置 - css-loader,style-loader:两个建议配合使用,用来解析css文件,能够解释@import,url(),如果需要解析less / sass就在后面加一个less-loader/sass-loader
- file-loader:生成的文件名就是文件内容的MD5哈希值并会保留所引用资源的原始扩展名
- url-loader: 功能类似 file-loader,但是文件大小低于指定的限制时,可以返回一个DataURL。事实上,在使用less,scss,stylus这些的时候,npm会提示你差什么插件,差什么,你就安装就行了
Plugin
loader 被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量。
想要使用一个插件,你只需要 require() 它,然后把它添加到 plugins 数组中。多数插件可以通过选项(option)自定义。你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用 new 操作符来创建它的一个实例。
const HtmlWebpackPlugin = require('html-webpack-plugin'); // 通过 npm 安装
const webpack = require('webpack'); // 用于访问内置插件
const config = {
module: {
rules: [
{ test: /\.txt$/, use: 'raw-loader' }
]
},
plugins: [
new HtmlWebpackPlugin({template: './src/index.html'})
// 依据一个简单的index.html模版,生成一个自动引用你打包后的js文件的新index.html
]
};
module.exports = config;
网友评论