既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
clean: true, // 自动将上次打包目录资源清空
},
module: {
rules: [
generator: {
// 将图片文件输出到 static/imgs 目录中
// 将图片文件命名 [hash:8][ext][query]
// [hash:8]: hash值取8位
// [ext]: 使用之前的文件扩展名
// [query]: 添加之前的query参数
filename: “static/imgs/[hash:8][ext][query]”,
},
},
],
},
plugins: [],
mode: “development”,
};
#### 开发服务器&自动化
起初我们想要查看打包好的文件,都是通过点击打开dist目录下的index.html,通过插件`open with live server` 在浏览器中查看。
插件`webpack-dev-server`可以实现自动化,我们可以看到每次打包好的页面。
执行命令下载:
npm i webpack-dev-server -D
配置 webpack.config.js
// 开发服务器
devServer: {
host: “localhost”, // 启动服务器域名
port: “3000”, // 启动服务器端口号
open: true, // 是否自动打开浏览器
},
整体文件
const path = require(“path”);
const HtmlWebpackPlugin = require(“html-webpack-plugin”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “dist”),
filename: “static/js/main.js”, // 将 js 文件输出到 static/js 目录中
clean: true, // 自动将上次打包目录资源清空
},
module: {
rules: [
generator: {
// 将图片文件输出到 static/imgs 目录中
// 将图片文件命名 [hash:8][ext][query]
// [hash:8]: hash值取8位
// [ext]: 使用之前的文件扩展名
// [query]: 添加之前的query参数
filename: “static/imgs/[hash:8][ext][query]”,
}
]
},
plugins: [
new HtmlWebpackPlugin({
// 以 public/index.html 为模板创建文件
// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源
template: path.resolve(__dirname, “public/index.html”),
}),
],
// 开发服务器
devServer: {
host: “localhost”, // 启动服务器域名
port: “3000”, // 启动服务器端口号
open: true, // 是否自动打开浏览器
},
mode: “development”,
};
执行命令:
npx webpack-dev-server --open
或
npx webpack serve
### 3.处理 html 资源
首先安装插件:
npm install html-webpack-plugin -D
并且调整 webpack.config.js 文件:
const path = require(“path”);
const HtmlWebpackPlugin = require(“html-webpack-plugin”);
module.exports = {
//…
plugins: [
// 实例化 html-webpack-plugin 插件
new HtmlWebpackPlugin()
]
}
打包后,我们发现这个 `dist/index.html` 似乎与先前的 `index.html` 并没有关系, `HtmlWebpackPlugin` 会默认生成它自己的 `index.html` 文件,并且所有的 `bundle(bundle.js)` 会自动添加到 html 中。
而我们想要基于原来的 index.html 来生成打包后的 dist/index.html
**可以对 html-webpack-plugin 插件进行配置来实现**
plugins: [
// 实例化 html-webpack-plugin 插件
new HtmlWebpackPlugin({
template: ‘./index.html’, // 以src目录下的 index.html 作为模板创建打包文件
filename: ‘app.html’, // 打包生成的文件名称。默认为index.html
// 设置所有资源文件注入模板的位置。
//可以设置的值 true|'head'|'body'|false,默认值为 true
inject: 'body'
})
]
### 4.处理样式资源
webpack 本身是不能识别样式资源的,所以我们需要借助 loader 来帮助 webpack 解析样式资源。
#### 处理 Css 资源
下载包
npm i css-loader style-loader -D
注意:需要下载两个 loader
功能介绍
* `css-loader`:负责将 Css 文件编译成 Webpack 能识别的模块
* `style-loader`:会动态创建一个 Style 标签,里面放置 Webpack 中 Css 模块内容
此时样式就会以 Style 标签的形式在页面上生效
配置
const path = require(“path”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “dist”),
filename: “main.js”,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.css$/,
// use 数组里面 Loader 执行顺序是从右到左
use: [“style-loader”, “css-loader”],
},
],
},
plugins: [],
mode: “development”,
};
添加 Css 资源
* src/css/index.css
.box1 {
width: 100px;
height: 100px;
background-color: pink;
}
* src/main.js
import count from “./js/count”;
import sum from “./js/sum”;
// 引入 Css 资源,Webpack才会对其打包
import “./css/index.css”;
console.log(count(2, 1));
console.log(sum(1, 2, 3, 4));
* public/index.html(打包好的文件)
Hello Webpack5
#### 处理 Less 资源
下载包
npm i less-loader -D
功能介绍
* `less-loader`:负责将 Less 文件编译成 Css 文件
配置
const path = require(“path”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “dist”),
filename: “main.js”,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 92: …oader"], }̲, { …/,
use: [“style-loader”, “css-loader”, “less-loader”],
},
],
},
plugins: [],
mode: “development”,
};
添加 Less 资源
* src/less/index.less
.box2 {
width: 100px;
height: 100px;
background-color: deeppink;
}
* src/main.js
import count from “./js/count”;
import sum from “./js/sum”;
// 引入资源,Webpack才会对其打包
import “./css/index.css”;
import “./less/index.less”;
console.log(count(2, 1));
console.log(sum(1, 2, 3, 4));
* public/index.html
Hello Webpack5
#### 处理 Sass 和 Scss 资源
下载包
npm i sass-loader sass -D
注意:需要下载两个
功能介绍
* `sass-loader`:负责将 Sass 文件编译成 css 文件
* `sass`:`sass-loader` 依赖 `sass` 进行编译
配置
const path = require(“path”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “dist”),
filename: “main.js”,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 92: …oader"], }̲, { …/,
use: [“style-loader”, “css-loader”, “less-loader”],
},
{
test: /.s[ac]ss$/,
use: [“style-loader”, “css-loader”, “sass-loader”],
},
],
},
plugins: [],
mode: “development”,
};
添加 Sass 资源
* src/sass/index.sass
/* 可以省略大括号和分号 */
.box3
width: 100px
height: 100px
background-color: hotpink
* src/sass/index.scss
.box4 {
width: 100px;
height: 100px;
background-color: lightpink;
}
* src/main.js
import count from “./js/count”;
import sum from “./js/sum”;
// 引入资源,Webpack才会对其打包
import “./css/index.css”;
import “./less/index.less”;
import “./sass/index.sass”;
import “./sass/index.scss”;
console.log(count(2, 1));
console.log(sum(1, 2, 3, 4));
* public/index.html
Hello Webpack5
#### 处理 Styl 资源
下载包
npm i stylus-loader -D
功能介绍
* `stylus-loader`:负责将 Styl 文件编译成 Css 文件
配置
const path = require(“path”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “dist”),
filename: “main.js”,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 92: …oader"], }̲, { …/,
use: [“style-loader”, “css-loader”, “less-loader”],
},
{
test: /.s[ac]ssKaTeX parse error: Expected 'EOF', got '}' at position 70: …oader"], }̲, { …/,
use: [“style-loader”, “css-loader”, “stylus-loader”],
},
],
},
plugins: [],
mode: “development”,
};
添加 Styl 资源
* src/styl/index.styl
/* 可以省略大括号、分号、冒号 */
.box
width 100px
height 100px
background-color pink
* src/main.js
import { add } from “./math”;
import count from “./js/count”;
import sum from “./js/sum”;
// 引入资源,Webpack才会对其打包
import “./css/index.css”;
import “./less/index.less”;
import “./sass/index.sass”;
import “./sass/index.scss”;
import “./styl/index.styl”;
console.log(count(2, 1));
console.log(sum(1, 2, 3, 4));
* public/index.html
Hello Webpack5
### 5.更多CSS处理
#### 提取 Css 成单独文件
Css 文件目前被打包到 js 文件中,当 js 文件加载时,会创建一个 style 标签来生成样式
这样对于网站来说,会出现闪屏现象,用户体验不好
**我们应该是单独的 Css 文件,通过 link 标签加载性能才好**
下载包
npm i mini-css-extract-plugin -D
配置
* webpack.prod.js
const path = require(“path”);
const HtmlWebpackPlugin = require(“html-webpack-plugin”);
const MiniCssExtractPlugin = require(“mini-css-extract-plugin”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “…/dist”), // 生产模式需要输出
filename: “static/js/main.js”, // 将 js 文件输出到 static/js 目录中
clean: true,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 105: …oader"], }̲, { …/,
use: [MiniCssExtractPlugin.loader, “css-loader”, “less-loader”],
},
{
test: /.s[ac]ssKaTeX parse error: Expected 'EOF', got '}' at position 83: …oader"], }̲, { …/,
use: [MiniCssExtractPlugin.loader, “css-loader”, “stylus-loader”],
}
]
},
plugins: [
new HtmlWebpackPlugin({
// 以 public/index.html 为模板创建文件
// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源
template: path.resolve(__dirname, “…/public/index.html”),
}),
// 提取css成单独文件
new MiniCssExtractPlugin({
// 定义输出文件名和目录
filename: “static/css/main.css”,
}),
],
// devServer: {
// host: “localhost”, // 启动服务器域名
// port: “3000”, // 启动服务器端口号
// open: true, // 是否自动打开浏览器
// },
mode: “production”,
};
#### Css 兼容性处理
下载包
npm i postcss-loader postcss postcss-preset-env -D
配置
* webpack.prod.js
const path = require(“path”);
const HtmlWebpackPlugin = require(“html-webpack-plugin”);
const MiniCssExtractPlugin = require(“mini-css-extract-plugin”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “…/dist”), // 生产模式需要输出
filename: “static/js/main.js”, // 将 js 文件输出到 static/js 目录中
clean: true,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 389: … ], }̲, { …/,
use: [
MiniCssExtractPlugin.loader,
“css-loader”,
{
loader: “postcss-loader”,
options: {
postcssOptions: {
plugins: [
“postcss-preset-env”, // 能解决大多数样式兼容性问题
],
},
},
},
“less-loader”,
],
},
{
test: /.s[ac]ssKaTeX parse error: Expected 'EOF', got '}' at position 377: … ], }̲, { …/,
use: [
MiniCssExtractPlugin.loader,
“css-loader”,
{
loader: “postcss-loader”,
options: {
postcssOptions: {
plugins: [
“postcss-preset-env”, // 能解决大多数样式兼容性问题
],
},
},
},
“stylus-loader”,
]
}
]
},
plugins: [
new HtmlWebpackPlugin({
// 以 public/index.html 为模板创建文件
// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源
template: path.resolve(__dirname, “…/public/index.html”),
}),
// 提取css成单独文件
new MiniCssExtractPlugin({
// 定义输出文件名和目录
filename: “static/css/main.css”,
}),
],
// devServer: {
// host: “localhost”, // 启动服务器域名
// port: “3000”, // 启动服务器端口号
// open: true, // 是否自动打开浏览器
// },
mode: “production”,
};
控制兼容性
我们可以在 `package.json` 文件中添加 `browserslist` 来控制样式的兼容性做到什么程度。
{
// 其他省略
“browserslist”: [“ie >= 8”]
}
以上为了测试兼容性所以设置兼容浏览器 ie8 以上。
实际开发中我们一般不考虑旧版本浏览器了,所以我们可以这样设置:
{
// 其他省略
“browserslist”: [“last 2 version”, “> 1%”, “not dead”]
}
合并配置
* webpack.prod.js
const path = require(“path”);
const HtmlWebpackPlugin = require(“html-webpack-plugin”);
const MiniCssExtractPlugin = require(“mini-css-extract-plugin”);
// 获取处理样式的Loaders
const getStyleLoaders = (preProcessor) => {
return [
MiniCssExtractPlugin.loader,
“css-loader”,
{
loader: “postcss-loader”,
options: {
postcssOptions: {
plugins: [
“postcss-preset-env”, // 能解决大多数样式兼容性问题
],
},
},
},
preProcessor,
].filter(Boolean);
};
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “…/dist”), // 生产模式需要输出
filename: “static/js/main.js”, // 将 js 文件输出到 static/js 目录中
clean: true,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 79: …aders(), }̲, { …/,
use: getStyleLoaders(“less-loader”),
},
{
test: /.s[ac]ssKaTeX parse error: Expected 'EOF', got '}' at position 55: …oader"), }̲, { …/,
use: getStyleLoaders(“stylus-loader”),
}
]
},
plugins: [
new HtmlWebpackPlugin({
// 以 public/index.html 为模板创建文件
// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源
template: path.resolve(__dirname, “…/public/index.html”),
}),
// 提取css成单独文件
new MiniCssExtractPlugin({
// 定义输出文件名和目录
filename: “static/css/main.css”,
}),
],
// devServer: {
// host: “localhost”, // 启动服务器域名
// port: “3000”, // 启动服务器端口号
// open: true, // 是否自动打开浏览器
// },
mode: “production”,
};
#### Css 压缩
下载包
npm i css-minimizer-webpack-plugin -D
配置
* webpack.prod.js
const path = require(“path”);
const HtmlWebpackPlugin = require(“html-webpack-plugin”);
const MiniCssExtractPlugin = require(“mini-css-extract-plugin”);
const CssMinimizerPlugin = require(“css-minimizer-webpack-plugin”);
// 获取处理样式的Loaders
const getStyleLoaders = (preProcessor) => {
return [
MiniCssExtractPlugin.loader,
“css-loader”,
{
loader: “postcss-loader”,
options: {
postcssOptions: {
plugins: [
“postcss-preset-env”, // 能解决大多数样式兼容性问题
],
},
},
},
preProcessor,
].filter(Boolean);
};
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “…/dist”), // 生产模式需要输出
filename: “static/js/main.js”, // 将 js 文件输出到 static/js 目录中
clean: true,
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 79: …aders(), }̲, { …/,
use: getStyleLoaders(“less-loader”),
},
{
test: /.s[ac]ssKaTeX parse error: Expected 'EOF', got '}' at position 55: …oader"), }̲, { …/,
use: getStyleLoaders(“stylus-loader”),
}
]
},
plugins: [
new HtmlWebpackPlugin({
// 以 public/index.html 为模板创建文件
// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源
template: path.resolve(__dirname, “…/public/index.html”),
}),
// 提取css成单独文件
new MiniCssExtractPlugin({
// 定义输出文件名和目录
filename: “static/css/main.css”,
}),
// css压缩
new CssMinimizerPlugin(),
],
// devServer: {
// host: “localhost”, // 启动服务器域名
// port: “3000”, // 启动服务器端口号
// open: true, // 是否自动打开浏览器
// },
mode: “production”,
};
### 6.处理 js 资源
有人可能会问,js 资源 Webpack 不能已经处理了吗,为什么我们还要处理呢?
**原因是 Webpack 对 js 处理是有限的,只能编译 js 中 ES 模块化语法,不能编译其他语法,导致 js 不能在 IE 等浏览器运行,所以我们希望做一些兼容性处理。**
**其次开发中,团队对代码格式是有严格要求的,我们不能由肉眼去检测代码格式,需要使用专业的工具来检测。**
* 针对 js 兼容性处理,我们使用 Babel 来完成
* 针对代码格式,我们使用 Eslint 来完成
我们先完成 Eslint,检测代码格式无误后,在由 Babel 做代码兼容性处理
#### Eslint
可组装的 JavaScript 和 JSX 检查工具。
这句话意思就是:它是用来检测 js 和 jsx 语法的工具,可以配置各项功能
我们使用 Eslint,关键是写 Eslint 配置文件,里面写上各种 rules 规则,将来运行 Eslint 时就会以写的规则对代码进行检查
配置文件
配置文件由很多种写法:
* ```
.eslintrc.*
:新建文件,位于项目根目录
+ `.eslintrc`
+ `.eslintrc.js`
+ `.eslintrc.json`
+ 区别在于配置格式不一样
package.json
中eslintConfig
:不需要创建文件,在原有文件基础上写
ESLint 会查找和自动读取它们,所以以上配置文件只需要存在一个即可
具体配置
我们以 .eslintrc.js
配置文件为例:
module.exports = {
// 解析选项
parserOptions: {},
// 具体检查规则
rules: {},
// 继承其他规则
extends: [],
// ...
};
- parserOptions 解析选项
parserOptions: {
ecmaVersion: 6, // ES 语法版本
sourceType: "module", // ES 模块化
ecmaFeatures: { // ES 其他特性
jsx: true // 如果是 React 项目,就需要开启 jsx 语法
}
}
- rules 具体规则
"off"
或0
- 关闭规则"warn"
或1
- 开启规则,使用警告级别的错误:warn
(不会导致程序退出)"error"
或2
- 开启规则,使用错误级别的错误:error
(当被触发的时候,程序会退出)
rules: {
semi: "error", // 禁止使用分号
'array-callback-return': 'warn', // 强制数组方法的回调函数中有 return 语句,否则警告
'default-case': [
'warn', // 要求 switch 语句中有 default 分支,否则警告
{ commentPattern: '^no default$' } // 允许在最后注释 no default, 就不会有警告了
],
eqeqeq: [
'warn', // 强制使用 === 和 !==,否则警告
'smart' // https://eslint.bootcss.com/docs/rules/eqeqeq#smart 除了少数情况下不会有警告
],
}
- extends 继承
开发中一点点写 rules 规则太费劲了,所以有更好的办法,继承现有的规则。
现有以下较为有名的规则:
- Eslint 官方的规则open in new window:
eslint:recommended
- Vue Cli 官方的规则open in new window:
plugin:vue/essential
- React Cli 官方的规则open in new window:
react-app
// 例如在React项目中,我们可以这样写配置
module.exports = {
extends: ["react-app"],
rules: {
// 我们的规则会覆盖掉react-app的规则
// 所以想要修改规则直接改就是了
eqeqeq: ["warn", "smart"],
},
};
在 Webpack 中使用
- 下载包
npm i eslint-webpack-plugin eslint -D
- 定义 Eslint 配置文件
- .eslintrc.js
module.exports = {
// 继承 Eslint 规则
extends: ["eslint:recommended"],
env: {
node: true, // 启用node中全局变量
browser: true, // 启用浏览器中全局变量
},
parserOptions: {
ecmaVersion: 6,
sourceType: "module",
},
rules: {
"no-var": 2, // 不能使用 var 定义变量
},
};
- 修改 js 文件代码
- main.js
import count from "./js/count";
import sum from "./js/sum";
// 引入资源,Webpack才会对其打包
import "./css/iconfont.css";
import "./css/index.css";
import "./less/index.less";
import "./sass/index.sass";
import "./sass/index.scss";
import "./styl/index.styl";
var result1 = count(2, 1);
console.log(result1);
var result2 = sum(1, 2, 3, 4);
console.log(result2);
- 配置
- webpack.config.js
const path = require("path");
const ESLintWebpackPlugin = require("eslint-webpack-plugin");
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
filename: "static/js/main.js", // 将 js 文件输出到 static/js 目录中
clean: true, // 自动将上次打包目录资源清空
},
module: {
rules: [
{
// 用来匹配 .css 结尾的文件
test: /\.css$/,
// use 数组里面 Loader 执行顺序是从右到左
use: ["style-loader", "css-loader"],
},
{
test: /\.less$/,
use: ["style-loader", "css-loader", "less-loader"],
}
]
},
plugins: [
new ESLintWebpackPlugin({
// 指定检查文件的根目录
context: path.resolve(__dirname, "src"),
}),
],
mode: "development",
};
VSCode Eslint 插件
打开 VSCode,下载 Eslint 插件,即可不用编译就能看到错误,可以提前解决
但是此时就会对项目所有文件默认进行 Eslint 检查了,我们 dist 目录下的打包后文件就会报错。但是我们只需要检查 src 下面的文件,不需要检查 dist 下面的文件。
所以可以使用 Eslint 忽略文件解决。在项目根目录新建下面文件:
.eslintignore
# 忽略dist目录下所有文件
dist
Babel
JavaScript 编译器。
主要用于将 ES6 语法编写的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中
配置文件
配置文件由很多种写法:
babel.config.*
:新建文件,位于项目根目录
+ `babel.config.js`
+ `babel.config.json`
* ```
.babelrc.*
:新建文件,位于项目根目录
+ `.babelrc`
+ `.babelrc.js`
+ `.babelrc.json`
package.json
中babel
:不需要创建文件,在原有文件基础上写
Babel 会查找和自动读取它们,所以以上配置文件只需要存在一个即可
具体配置
我们以 babel.config.js
配置文件为例:
module.exports = {
// 预设
presets: [],
};
- presets 预设
简单理解:就是一组 Babel 插件, 扩展 Babel 功能
@babel/preset-env
: 一个智能预设,允许您使用最新的 JavaScript。@babel/preset-react
:一个用来编译 React jsx 语法的预设@babel/preset-typescript
:一个用来编译 TypeScript 语法的预设
在 Webpack 中使用
- 下载包
npm i babel-loader @babel/core @babel/preset-env -D
- 定义 Babel 配置文件
- babel.config.js
module.exports = {
presets: ["@babel/preset-env"],
};
- 修改 js 文件代码
- main.js
import count from "./js/count";
import sum from "./js/sum";
// 引入资源,Webpack才会对其打包
import "./css/iconfont.css";
import "./css/index.css";
import "./less/index.less";
import "./sass/index.sass";
import "./sass/index.scss";
import "./styl/index.styl";
const result1 = count(2, 1);
console.log(result1);
const result2 = sum(1, 2, 3, 4);
console.log(result2);
- 配置
- webpack.config.js
const path = require("path");
const ESLintWebpackPlugin = require("eslint-webpack-plugin");
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
![img](https://img-blog.csdnimg.cn/img_convert/b0f686eb82ca0ca61329e06747a49a3b.png)
![img](https://img-blog.csdnimg.cn/img_convert/7ff230c3f75beb7a04eb0c1b11cdf98d.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
module.exports = {
// 预设
presets: [],
};
1. presets 预设
简单理解:就是一组 Babel 插件, 扩展 Babel 功能
* `@babel/preset-env`: 一个智能预设,允许您使用最新的 JavaScript。
* `@babel/preset-react`:一个用来编译 React jsx 语法的预设
* `@babel/preset-typescript`:一个用来编译 TypeScript 语法的预设
##### 在 Webpack 中使用
1. 下载包
npm i babel-loader @babel/core @babel/preset-env -D
2. 定义 Babel 配置文件
* babel.config.js
module.exports = {
presets: [“@babel/preset-env”],
};
3. 修改 js 文件代码
* main.js
import count from “./js/count”;
import sum from “./js/sum”;
// 引入资源,Webpack才会对其打包
import “./css/iconfont.css”;
import “./css/index.css”;
import “./less/index.less”;
import “./sass/index.sass”;
import “./sass/index.scss”;
import “./styl/index.styl”;
const result1 = count(2, 1);
console.log(result1);
const result2 = sum(1, 2, 3, 4);
console.log(result2);
4. 配置
* webpack.config.js
const path = require(“path”);
const ESLintWebpackPlugin = require(“eslint-webpack-plugin”);
module.exports = {
entry: “./src/main.js”,
output: {
path: path.resolve(__dirname, “dist”),
[外链图片转存中…(img-BTVZ1upd-1715264212005)]
[外链图片转存中…(img-LglOEymN-1715264212005)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!