【webpack笔记】webpack_Eslint_Babel(03)
Page content
这一篇整理了Eslint和Babel相关的内容。
- Eslint处理代码格式问题
- Babel处理js兼容性问题
1.Eslint
是用来检测js和jsx语法的工具
配置文件由很多种写法
.eslintrc.js 配置文件
module.exports = {
// 解析选项
parserOptions: {
ecmaVersion: 6, // ES 语法版本
sourceType: "module", // ES 模块化
ecmaFeatures: { // ES 其他特性
jsx: true // 如果是 React 项目,就需要开启 jsx 语法
}
},
// 具体检查规则
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: [],
// ...
// 其他规则详见:https://eslint.bootcss.com/docs/user-guide/configuring
};
Eslint 官方的规则 :eslint:recommended
Vue Cli 官方的规则:plugin:vue/essential
1.1 下载包
npm i eslint-webpack-plugin eslint -D
1.2 定义Eslint
配置文件 .eslintrc.js
1.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";
var result1 = count(2, 1);
console.log(result1);
var result2 = sum(1, 2, 3, 4);
console.log(result2);
1.4 配置webpack.config.js
const path = require("path");
const ESLintWebpackPlugin = require("eslint-webpack-plugin");
module.exports = {
entry: "./src/main.js",
... ... ...
plugins: [
new ESLintWebpackPlugin({
// 指定检查文件的根目录
context: path.resolve(__dirname, "src"),
}),
],
mode: "development",
};
1.5 运行指令
npx webpack
1.6 .eslintignore配置
# 忽略dist目录下所有文件
dist
2.Babel
将 ES6 语法编写的代码转换为向后兼容的JavaScript语法。 配置文件有很多种写法
2.1 下载包
npm i babel-loader @babel/core @babel/preset-env -D
2.2 presets 预设
就是一组Babel插件, 扩展Babel功能
@babel/preset-env: 一个智能预设,允许您使用最新的 JavaScript。
@babel/preset-react:一个用来编译 React jsx 语法的预设
@babel/preset-typescript:一个用来编译 TypeScript 语法的预设
babel.config.js
module.exports = {
presets: ["@babel/preset-env"],
};
2.3 webpack配置
webpack.config.js
const path = require("path");
const ESLintWebpackPlugin = require("eslint-webpack-plugin");
module.exports = {
module: {
rules: [
... ... ...
{
test: /\.js$/,
exclude: /node_modules/, // 排除node_modules代码不编译
loader: "babel-loader",
},
],
},
... ... ...
mode: "development",
};
2.4 运行指令
npx webpack
打开打包后的 dist/static/js/main.js 文件查看,会发现箭头函数等 ES6 语法已经转换
欢迎大家的意见和交流
email: li_mingxie@163.com