概述
webpack5.x 发布至今已经将近两个月了, v5 版本内置了一些常用的插件, 较 v4 版本有很大的变化. 本文基于 webpack5.x 以及 vue2.x, 从零搭建一个基础模板:
项目地址: github.com/ddzy/vue2-w…
也可以通过脚手架工具, 快捷安装:
脚手架地址: github.com/ddzy/vue2-w…
目录
- 项目主依赖
- 项目结构
- 集成本地开发环境
- 集成模块热替换
- 集成 HTML
- 集成 SCSS
- 集成 TS + Babel
- 集成 Vue
- 集成图片
- 集成其它文件
- 集成 ESlint
- 集成 prettier
- 集成 Husky & lint-staged
- 集成 VS Code
项目主依赖
Name | Version | Link |
---|---|---|
vue | 2.6.12 | github.com/vuejs/vue |
webpack | 5.10.3 | github.com/webpack/web… |
webpack-cli | 4.2.0 | github.com/webpack/web… |
项目结构
|-- .vscode |-- dist // 打包输出目录 |-- src // 源码目录 | |-- @types // ts 全局声明文件(*.d.ts) | |-- assets | |-- components | |-- utils | |-- views | |-- app.vue | |-- index.html | -- main.ts |-- LICENSE |-- README.md |-- .browserslistrc |-- .eslintrc.js |-- .gitignore |-- .prettierrc.js |-- babel.config.json |-- package.json |-- tsconfig.json |-- webpack.config.ts |-- yarn.lock复制代码
集成本地开发环境
所需依赖
Name | Version | Link |
---|---|---|
webpack-dev-server | 3.11.0 | github.com/webpack/web… |
配置流程
- 安装相关依赖
yarn add --dev webpack-dev-server复制代码
- 配置 webpack.config.ts
import * as Webpack from "webpack";export default { ... devServer: { contentBase: path.resolve(__dirname, 'dist'), open: true, port: 8888, compress: true, clientLogLevel: 'silent', noInfo: true, }, ... } as Webpack.Configuration;;复制代码
- 配置 package.json
{ ... "scripts": {"build": "cross-env NODE_ENV=production webpack --config ./webpack.config.ts","start": "cross-env NODE_ENV=development webpack serve","serve": "yarn start", } ... }复制代码
集成模块热替换
所需依赖
略
配置流程
- 配置 webpack.config.ts
import * as Webpack from "webpack";复制代码
export default { ... plugins: [+ new Webpack.HotModuleReplacementPlugin(), ], devServer: {+ hot: true, }, ... };复制代码
集成HTML
所需依赖
Name | Version | Link |
---|---|---|
html-webpack-plugin | 5.0.0-alpha.3 | github.com/jantimon/ht… |
配置流程
- 安装相关依赖
yarn add --dev html-webpack-plugin复制代码
- 配置 webpack.config.ts
import * as HtmlWebpackPlugin from 'html-webpack-plugin'; export default { ... plugins: [+ new HtmlWebpackPlugin({+ template: 'src/index.html', // 自定义 HTML 模板+ }), ], ... } as Webpack.Configuration;复制代码
集成SCSS
所需依赖
Name | Version | Link |
---|---|---|
sass | 1.30.0 | github.com/sass/sass |
sass-loader | 10.1.0 | github.com/webpack-con… |
node-sass | 5.0.0 | github.com/sass/node-s… |
mini-css-extract-plugin | 1.3.3 | github.com/webpack-con… |
postcss | 8.2.1 | github.com/postcss/pos… |
postcss-loader | 4.1.0 | github.com/webpack-con… |
postcss-preset-env | 6.7.0 | github.com/csstools/po… |
配置流程
- 安装相关依赖
yarn add --dev sass sass-loader node-sass postcss mini-css-extract-plugin复制代码
- 配置 webpack.config.ts
+ import * as MiniCssExtractPlugin from 'mini-css-extract-plugin';export default { ...+ module: {+ rules: [+ {+ test: /\.css|sass|scss$/,+ use: [+ {+ loader: MiniCssExtractPlugin.loader,+ },+ {+ loader: 'css-loader',+ },+ {+ loader: 'postcss-loader',+ options: {+ postcssOptions: {+ plugins: [['postcss-preset-env', {}]],+ },+ },+ },+ {+ loader: 'sass-loader',+ },+ ],+ },+ ],+ }, plugins: [+ new MiniCssExtractPlugin(), ], ... };复制代码
集成TS+Babel
所需依赖
Name | Version | Link |
---|---|---|
@babel/core | 7.12.10 | github.com/babel/babel… |
@babel/plugin-proposal-class-properties | 7.12.1 | github.com/babel/babel… |
@babel/plugin-proposal-decorators | 7.12.1 | github.com/babel/babel… |
@babel/plugin-transform-runtime | 7.12.10 | github.com/babel/babel… |
@babel/preset-env | 7.12.11 | github.com/babel/babel… |
@babel/preset-typescript | 7.12.7 | github.com/babel/babel… |
babel-loader | 8.2.2 | github.com/babel/babel… |
typescript | 4.1.3 | github.com/microsoft/T… |
tsconfig-paths-webpack-plugin | 3.3.0 | github.com/dividab/tsc… |
@babel/polyfill | 7.12.1 | github.com/babel/babel… |
@babel/runtime | 7.12.5 | github.com/babel/babel… |
配置流程
- 安装相关依赖
yarn add --dev @babel/core @babel/plugin-proposal-class-properties @babel/plugin-proposal-decorators @babel/plugin-transform-runtime @babel/preset-env @babel/preset-typescript babel-loader typescript tsconfig-paths-webpack-plugin yarn add @babel/polyfill @babel/runtime复制代码
- 配置 webpack.config.ts
import * as Webpack from 'webpack'; export default { ...- entry: './src/main.ts',+ entry: ['@babel/polyfill', './src/main.ts'], module: { rules: [ ...+ {+ test: /\.ts|js$/,+ exclude: /node_modules/,+ use: [+ {+ loader: 'babel-loader',+ },+ ],+ }, ... ], },+ resolve: {+ extensions: ['.ts', '.js'],+ plugins: [+ // 将 tsconfig 中配置的路径别名映射到 webpack.resolve.alias 上+ // 在 .vue 文件中可以通过诸如 @/components/xxx.vue 的形式来引入组件+ new TsconfigPathsPlugin(),+ ],+ }, ... } as Webpack.Configuration;复制代码
- 配置 babel.config.json
{ "presets": [ [ "@babel/preset-env", {"useBuiltIns": false } ], [ "@babel/preset-typescript", {"allExtensions": true } ] ], "plugins": [ [ "@babel/plugin-proposal-decorators", {"legacy": true } ], ["@babel/plugin-proposal-class-properties"], ["@babel/plugin-transform-runtime"] ] }复制代码
- 配置 tsconfig.json
{ "compilerOptions": {"sourceMap": true,"module": "CommonJS","target": "ES5","baseUrl": ".","rootDir": ".","allowJs": true,"experimentalDecorators": true,// 路径别名"paths": { "@/*": ["src/*"] } }, "include": ["src/**/*"], "exclude": ["node_modules", "dist"] }复制代码
集成Vue
所需依赖
Name | Version | Link |
---|---|---|
vue | 2.6.12 | github.com/vuejs/vue |
vue-class-component | 7.2.6 | github.com/vuejs/vue-c… |
vue-property-decorator | 9.1.2 | github.com/kaorun343/v… |
vue-loader | 15.9.6 | github.com/vuejs/vue-l… |
vue-template-compiler | 2.6.12 | github.com/vuejs/vue/t… |
配置流程
- 安装相关依赖
yarn add vue vue-class-component vue-property-decorator yarn add --dev vue-loader vue-template-compiler复制代码
- 配置 webpack.config.ts
import * as Webpack from 'webpack';+ const VueLoaderPlugin = require('vue-loader/lib/plugin-webpack5');export default { ... module: { rules: [ ...+ {+ test: /\.vue$/,+ use: [+ {+ loader: 'vue-loader',+ },+ ],+ }, ... ], }, plugins: [ ...+ new VueLoaderPlugin(),+ // 全局注入 Vue, 避免在每个 .vue 文件中重复引入+ new Webpack.ProvidePlugin({+ Vue: ['vue/dist/vue.esm.js', 'default'],+ }),... ], resolve: {- extensions: ['.ts', '.js'],+ extensions: ['.ts', '.js', '.vue'], }, ... } as Webpack.Configuration;复制代码
- 配置全局的 TS 声明文件
在 src/@types/ 目录下存放全局的 TS 声明文件(*.d.ts):
|-- src | |-- @types | | |-- files.d.ts | | |-- global.d.ts | | |-- images.d.ts | | |-- vue.d.ts复制代码
// ----------files.d.ts-----------// 声明一些原始格式的文件declare module "*.txt";declare module "*.xlsx";// ---------images.d.ts-----------declare module "*.png";declare module "*.jpg";declare module "*.jpeg";declare module "*.gif";declare module "*.svg";// ---------global.d.ts-----------// 配合 Webpack.ProvidePlugin 使用, 前面已配置好了import Vue from "vue";declare global { const Vue: typeof Vue; }// --------vue.d.ts---------------declare module "*.vue" { import Vue from "vue"; export default Vue; }declare module "vue/types/vue" { interface Vue {} }复制代码
集成图片
所需依赖
webpack5 内置了 asset 模块, 用来代替 file-loader & url-loader & raw-loader 处理静态资源
配置流程
- 配置 webpack.config.ts
import * as Webpack from 'webpack'; export default { ... module: { rules: [ ...+ {+ test: /\.png|jpg|gif|jpeg|svg/,+ type: 'asset',+ parser: {+ dataUrlCondition: {+ maxSize: 10 * 1024,+ },+ },+ generator: {+ filename: 'images/[base]',+ },+ }, ... ], }, ... } as Webpack.Configuration;复制代码
集成其它文件
所需依赖
webpack5 内置了 asset 模块, 用来代替 file-loader & url-loader & raw-loader 处理静态资源
配置流程
- 配置 webpack.config.ts
import * as Webpack from 'webpack'; export default { ... module: { rules: [ ...+ {+ test: /\.txt|xlsx/,+ type: 'asset',+ generator: {+ filename: 'files/[base]',+ },+ }, ... ], }, ... } as Webpack.Configuration;复制代码
集成ESlint
所需依赖
Name | Version | Link |
---|---|---|
eslint | 7.16.0 | github.com/eslint/esli… |
eslint-plugin-vue | 7.3.0 | github.com/vuejs/eslin… |
vue-eslint-parser | 7.3.0 | github.com/vuejs/vue-e… |
@typescript-eslint/eslint-plugin | 4.11.0 | github.com/typescript-… |
@typescript-eslint/parser | 4.11.0 | github.com/typescript-… |
配置流程
- 安装相关依赖
yarn add --dev eslint eslint-plugin-vue vue-eslint-parser @typescript-eslint/eslint-plugin @typescript-eslint/parser复制代码
- 配置 .eslintrc.js
module.exports = { parser: "vue-eslint-parser", // 解析 .vue 文件 parserOptions: {parser: "@typescript-eslint/parser", // 解析 .vue 文件里面的 script 标签 }, plugins: ["@typescript-eslint"], extends: ["plugin:vue/recommended", "plugin:@typescript-eslint/recommended"], rules: {// 定义其它校验规则"@typescript-eslint/no-extra-semi": ["error"],"@typescript-eslint/semi": ["error"],"@typescript-eslint/no-empty-interface": 0, }, };复制代码
- 配置 package.json
{ "scripts": { "build": "cross-env NODE_ENV=production webpack --config ./webpack.config.ts", "start": "cross-env NODE_ENV=development webpack serve", "serve": "yarn start",+ "lint": "eslint --fix \"src/**/*.{js,ts,jsx,tsx}\" \"src/**/*.vue\"", }, }复制代码
集成prettier
所需依赖
Name | Version | Link |
---|---|---|
prettier | 2.2.1 | github.com/prettier/pr… |
eslint-config-prettier | 7.1.0 | github.com/prettier/es… |
eslint-plugin-prettier | 3.3.0 | github.com/prettier/es… |
配置流程
- 安装相关依赖
yarn add --dev prettier eslint-config-prettier eslint-plugin-prettier复制代码
- 配置 .eslintrc.js
module.exports = { parser: 'vue-eslint-parser', // 解析 .vue 文件 parserOptions: { parser: '@typescript-eslint/parser', // 解析 .vue 文件里面的 script 标签 }, plugins: ['@typescript-eslint'], extends: [ 'plugin:vue/recommended',+ 'plugin:prettier/recommended',+ 'prettier/@typescript-eslint', 'plugin:@typescript-eslint/recommended', ], rules: { '@typescript-eslint/no-extra-semi': ['error'], '@typescript-eslint/semi': ['error'], '@typescript-eslint/no-empty-interface': 0, }, };复制代码
- 配置 .prettierrc.js
module.exports = { semi: true, // 语句后加分号 trailingComma: "all", // 尾随逗号(none |es5 | all) singleQuote: true, // 使用单引号 printWidth: 80, // 每一行的最大长度, 尽量和编辑器保持一致 tabWidth: 2, // Tab 缩进的长度 useTabs: true, // 使用 Tab 缩进 endOfLine: "auto", // 文件尾部换行的形式 arrowParens: "always", // 箭头函数参数使用小括号包裹};复制代码
- 配置 package.json
{ ... "scripts": { "build": "cross-env NODE_ENV=production webpack --config ./webpack.config.ts", "start": "cross-env NODE_ENV=development webpack serve", "serve": "yarn start", "lint": "eslint --fix \"src/**/*.{js,ts}\" \"src/**/*.vue\"",+ "format": "prettier --write \"src/**/*.{js,ts,jsx,tsx}\" \"src/**/*.vue\" ./*.{js,ts}" }, ... }复制代码
集成Husky和lint-staged
所需依赖
Name | Version | Link |
---|---|---|
husky | 4.3.6 | github.com/typicode/hu… |
lint-staged | 10.5.3 | github.com/okonet/lint… |
构建流程
- 安装相关依赖
yarn add --dev husky lint-staged复制代码
- 配置 package.json
{+ "husky": {+ "hooks": {+ "pre-commit": "lint-staged"+ }+ },+ "lint-staged": {+ "src/**/*.{ts,vue}": [+ "prettier --write",+ "eslint --fix"+ ]+ },}复制代码
集成VSCode
主要是在 VS Code 中集成 prettier, 便于在开发时进行代码的格式化
所需依赖
Name | Description | Link |
---|---|---|
Prettier - Code formatter | VS Code 上的 Prettier 插件 | github.com/prettier/pr… |
构建流程
- 安装插件
略
- 配置 .vscode
在项目根目录下新建 .vscode 文件夹, 并创建 settings.json 文件:
{ // 当在 VS Code 中进行右键 -> 格式化的时候, 读取的本地配置 // 这里直接读取项目的 prettier 配置文件 "prettier.configPath": ".prettierrc.js"}复制代码