1. Что такое веб-пакет
WebPack можно рассматривать как упаковщик модулей: он анализирует структуру вашего проекта, находит модули JavaScript и другие языки расширения (Scss, TypeScript и т. д.), которые браузеры не могут запускать напрямую, и упаковывает их в подходящий формат для браузера. использовать.
2. Основные концепции веб-пакета
- Entry: Entry, первый шаг в выполнении сборки Webpack начнется с Entry, который можно абстрагировать во входные данные.
- Модуль: модуль, все является модулем в Webpack, а модуль соответствует файлу. Webpack будет рекурсивно находить все зависимые модули, начиная с настроенного Entry.
- Чанк: блок кода, фрагмент состоит из нескольких модулей для слияния и разделения кода. Загрузчик: преобразователь модулей, который используется для преобразования исходного содержимого модуля в новое содержимое по мере необходимости.
- Плагин: плагин расширения, который внедряет логику расширения в определенное время в процессе сборки Webpack, чтобы изменить результат сборки или сделать то, что вы хотите.
- Вывод: выведите результат после того, как Webpack пройдет серию обработок и получит окончательный желаемый код.
3. процесс выполнения веб-пакета
После запуска веб-пакета модуль, настроенный в записи, начнет рекурсивно анализировать все модули, от которых зависит запись. Если модуль не найден, он найдет соответствующие правила преобразования в соответствии с настроенным загрузчиком. После преобразования модуля, он будет анализировать текущий модуль, зависящий от модуля, эти модули будут сгруппированы по записи. Запись и все зависимые модули также являются чанком. Наконец, webpack преобразует все чанки в выходной файл. В течение всего процесса веб-пакет будет выполнять логику плагина в нужное время.
4. Начать настройку webpack с нуля
- Начальная конфигурация
mkdir webpack-start
cd webpack-start
npm init
- настроить веб-пакет
yarn add webpack webpack-cli -D //webpack4把webpack拆分了
mkdir src cd src并且创建index.html, index.js
mkdir dist
touch webpack.config.js
webpack.config.js
module.exports = {
entry: './src/index.js', //入口文件,src下的index.js
output: {
path: path.join(__dirname, 'dist'), // 出口目录,dist文件
filename: '[name].[hash].js' //这里name就是打包出来的文件名,因为是单入口,就是main,多入口下回分解
},
module: {},
plugin: {},
devServer: {}
}
- Настроить сервер разработки
yarn add webpack-dev-server -D
修改webpack.config.js
devServer: {
contentBase: path.join(__dirname, "dist"), //静态文件根目录
port: 9090, // 端口
host: 'localhost',
overlay: true,
compress: true // 服务器返回浏览器的时候是否启动gzip压缩
}
修改package.json
"script": {
"build": "webpack --mode development", //这里为了不压缩代码,用开发环境
"dev": "webpack-dev-server --open --mode development"
}
- Поддержка css-файлов
yarn add style-loader css-loader -D
// css-loader用来处理css中url的路径
// style-loader可以把css文件变成style标签插入head中
// 多个loader是有顺序要求的,从右往左写,因为转换的时候是从右往左转换的
module: {
rules: {
test: /\.css$/,
use: ['style-laoder', 'css-loader'],
include: path.join(__dirname, 'src'), //限制范围,提高打包速度
exclude: /node_modules/
}
}
- Поддержка es6, react.js и т.д.
yarn add babel-loader babel-core babel-preset-env babel-preset-stage-0 babel-preset -react -D
{
test: /\.js$/,
use: {
loader: 'babel-loader',
query: {
presets: ['env', 'stage-0', 'react'] // env转换es6 stage-0转es7 react转react
}
}
}
同时可以把babel配置写到.babelrc中
- отделить css от js
yarn add extract-text-webpack-plugin -D
{
test: /\.css$/, // 转换文件的匹配正则
use: ExtractTextWebpackPlugin.extract({
fallback: 'style-loader',
//如果需要,可以在 sass-loader 之前将 resolve-url-loader 链接进来
use: ['css-loader']
})
},
//加上plugin
plugins: [
new ExtractTextWebpackPlugin({
filename: 'css/[name].[hash].css' //放到dist/css/下
})
]
- Поддержка изображений
yarn add file-loader url-loader -D
file-loader 解决css等文件中引入图片路径的问题
url-loader 当图片较小的时候会把图片BASE64编码,大于limit参数的时候还是使用file-loader 进行拷贝
{
// file-loader是解析图片地址,把图片从源文件拷贝到目标文件并且修改源文件名字
// 可以处理任意二进制,bootstrap里的字体
// url-loader可以在文件比较小的时候,直接变成base64字符串内嵌到页面中
{
test: /\.(png|jpg|jpeg|gif|svg)/,
use: {
loader: 'url-loader',
options: {
outputPath: 'images/', // 图片输出的路径
limit: 5 * 1024
}
}
},
// 同时要处理打包图片路径问题,
output: {
publicPath: '/'
}
- Обработка префиксов свойств css3
yarn add postcss-loader -D
{
test: /\.css$/, // 转换文件的匹配正则
// css-loader用来处理css中url的路径
// style-loader可以把css文件变成style标签插入head中
// 多个loader是有顺序要求的,从右往左写,因为转换的时候是从右往左转换的
// 此插件先用css-loader处理一下css文件
use: ExtractTextWebpackPlugin.extract({
fallback: 'style-loader',
//如果需要,可以在 sass-loader 之前将 resolve-url-loader 链接进来
use: ['css-loader', 'postcss-loader']
})
},
建立.postcssrc.js文件
module.exports = {
"plugins": {
// to edit target browsers: use "browserslist" field in package.json
"autoprefixer": {
"browsers": [
"ie >= 9",
"ff >= 30",
"chrome >= 34",
"safari >= 7",
"opera >= 23"
]
}
}
}
- Отладка упакованного кода webapck может автоматически предоставлять нам файлы исходных карт через конфигурацию, файлы карт — это способ сопоставления скомпилированных файлов и исходных файлов.
devtool: 'eval-source-map'
1. source-map 把映射文件生成到单独的文件,最完整最慢
2. cheap-module-source-map 在一个单独的文件中产生一个不带列映射的Map
3. eval-source-map 使用eval打包源文件模块,在同一个文件中生成完整sourcemap
4. cheap-module-eval-source-map sourcemap和打包后的JS同行显示,没有映射列
- сжать js
webpack --mode production 会压缩,可以忽略下面
yarn add uglifyjs-webpack-plugin -D
const UglifyjsWebpackPlugin = require('uglifyjs-webpack-plugin')
new UglifyjsWebpackPlugin(),
- сжать css
webpack --mode production 会压缩,可以忽略下面
{
test: /\.css$/, // 转换文件的匹配正则
use: ExtractTextWebpackPlugin.extract({
fallback: 'style-loader',
use: [
{
loader: 'css-laoder',
options: {minimize: true}
},
'postcss-loader'
]
})
},
- Очистить выходной каталог пакета
yarn add clean-webpack-plugin -D
const CleanWebpackPlugin = require('clean-webpack-plugin')
new CleanWebpackPlugin([path.join(__dirname, 'dist')]),
- Различать переменные среды Многие библиотеки будут связаны с переменной среды process.env.NODE_ENV, чтобы определить, на что следует ссылаться в библиотеке. Мы можем использовать DefinePlugin, встроенный в webpack, чтобы определить эту переменную для всех зависимостей:
"scripts": {
"build": "cross-env NODE_ENV=production webpack --mode development", // 设置NODE_ENV为production
"dev": "webpack-dev-server --open --mode development "
},
new webpack.DefinePlugin({
NODE_ENV:JSON.stringify(process.env.NODE_ENV)
})
在全局都有NODE_ENV这个变量,当yarn run build,时,NODE_ENV = 'production'
- Показать глобальные переменные
new Webpack.ProvidePlugin({
'$': 'jquery'
}),
- разрешить
xtension: 指定extension之后可以不用在require或是import的时候加文件扩展名,会依次尝试添加扩展名进行匹配
resolve: {
//自动补全后缀,注意第一个必须是空字符串,后缀一定以点开头
extension: ['', '.js', '.json', '.css']
}
alias: 配置别名可以加快webpack查找模块的速度
resolve: {
alias: {
'bootstrap': 'bootstrap/dist/css/bootstrap.css'
}
}
- Копировать статические ресурсы
yarn add copy-webpack-plugin
const CopyWebpackPlugin = require('copy-webpack-plugin')
new CopyWebpackPlugin([
{
from: path.resolve(__dirname, 'static'),
to: path.resolve(__dirname, 'pages/static'),
ignore: ['.*']
}
])
Это основы, оптимизация кода, повышение скорости упаковки, многостраничная конфигурация, давайте разберем ее в следующий раз, подробности см. в разделе расширенная конфигурация веб-пакета.