标签 ESLint 下的文章

ESLint配置清单

ESLint官方提供的一份标准配置
阿里eslint-config-ali
腾讯AlloyTeamAlloyTeam ESLint 配置指南
Airbnb JavaScript Style Guide

手摸手教你定制ESLint rule以及了解ESLint的运行原理

凹凸实验室前端代码规范
风格指南

"no-alert": 0,//禁⽌使⽤alert confirm prompt
"no-array-constructor": 2,//禁⽌使⽤数组构造器
"no-bitwise": 0,//禁⽌使⽤按位运算符
"no-caller": 1,//禁⽌使⽤arguments.caller或arguments.callee
"no-catch-shadow": 2,//禁⽌catch⼦句参数与外部作⽤域变量同名
"no-class-assign": 2,//禁⽌给类赋值
"no-cond-assign": 2,//禁⽌在条件表达式中使⽤赋值语句
"no-console": 2,//禁⽌使⽤console
"no-const-assign": 2,//禁⽌修改const声明的变量
"no-constant-condition": 2,//禁⽌在条件中使⽤常量表达式 if(true) if(1)
"no-continue": 0,//禁⽌使⽤continue
"no-control-regex": 2,//禁⽌在正则表达式中使⽤控制字符
"no-debugger": 2,//禁⽌使⽤debugger
"no-delete-var": 2,//不能对var声明的变量使⽤delete操作符
"no-div-regex": 1,//不能使⽤看起来像除法的正则表达式/=foo/
"no-dupe-keys": 2,//在创建对象字⾯量时不允许键重复 {a:1,a:1}
"no-dupe-args": 2,//函数参数不能重复
"no-duplicate-case": 2,//switch中的case标签不能重复
"no-else-return": 2,//如果if语句⾥⾯有return,后⾯不能跟else语句
"no-empty": 2,//块语句中的内容不能为空
"no-empty-character-class": 2,//正则表达式中的[]内容不能为空
"no-empty-label": 2,//禁⽌使⽤空label
"no-eq-null": 2,//禁⽌对null使⽤==或!=运算符
"no-eval": 1,//禁⽌使⽤eval
"no-ex-assign": 2,//禁⽌给catch语句中的异常参数赋值
"no-extend-native": 2,//禁⽌扩展native对象
"no-extra-bind": 2,//禁⽌不必要的函数绑定
"no-extra-boolean-cast": 2,//禁⽌不必要的bool转换
"no-extra-parens": 2,//禁⽌⾮必要的括号
"no-extra-semi": 2,//禁⽌多余的冒号
"no-fallthrough": 1,//禁⽌switch穿透
"no-floating-decimal": 2,//禁⽌省略浮点数中的0 .5 3.
"no-func-assign": 2,//禁⽌重复的函数声明
"no-implicit-coercion": 1,//禁⽌隐式转换
"no-implied-eval": 2,//禁⽌使⽤隐式eval
"no-inline-comments": 0,//禁⽌⾏内备注
"no-inner-declarations": [2, "functions"],//禁⽌在块语句中使⽤声明(变量或函数)
"no-invalid-regexp": 2,//禁⽌⽆效的正则表达式
"no-invalid-this": 2,//禁⽌⽆效的this,只能⽤在构造器,类,对象字⾯量
"no-irregular-whitespace": 2,//不能有不规则的空格
"no-iterator": 2,//禁⽌使⽤__iterator__ 属性
"no-label-var": 2,//label名不能与var声明的变量名相同
"no-labels": 2,//禁⽌标签声明
"no-lone-blocks": 2,//禁⽌不必要的嵌套块
"no-lonely-if": 2,//禁⽌else语句内只有if语句
"no-loop-func": 1,//禁⽌在循环中使⽤函数(如果没有引⽤外部变量不形成闭包就可以)
"no-mixed-requires": [0, false],//声明时不能混⽤声明类型
"no-mixed-spaces-and-tabs": [2, false],//禁⽌混⽤tab和空格
"linebreak-style": [0, "windows"],//换⾏⻛格
"no-multi-spaces": 1,//不能⽤多余的空格
"no-multi-str": 2,//字符串不能⽤\换⾏
"no-multiple-empty-lines": [1, {"max": 2}],//空⾏最多不能超过2⾏
"no-native-reassign": 2,//不能重写native对象
"no-negated-in-lhs": 2,//in 操作符的左边不能有!
"no-nested-ternary": 0,//禁⽌使⽤嵌套的三⽬运算
"no-new": 1,//禁⽌在使⽤new构造⼀个实例后不赋值
"no-new-func": 1,//禁⽌使⽤new Function
"no-new-object": 2,//禁⽌使⽤new Object()
"no-new-require": 2,//禁⽌使⽤new require
"no-new-wrappers": 2,//禁⽌使⽤new创建包装实例,new String new Boolean new Number
"no-obj-calls": 2,//不能调⽤内置的全局对象,⽐如Math() JSON()
"no-octal": 2,//禁⽌使⽤⼋进制数字
"no-octal-escape": 2,//禁⽌使⽤⼋进制转义序列
"no-param-reassign": 2,//禁⽌给参数重新赋值
"no-path-concat": 0,//node中不能使⽤__dirname或__filename做路径拼接
"no-plusplus": 0,//禁⽌使⽤++,--
"no-process-env": 0,//禁⽌使⽤process.env
"no-process-exit": 0,//禁⽌使⽤process.exit()
"no-proto": 2,//禁⽌使⽤__proto__属性
"no-redeclare": 2,//禁⽌重复声明变量
"no-regex-spaces": 2,//禁⽌在正则表达式字⾯量中使⽤多个空格 /foo bar/
"no-restricted-modules": 0,//如果禁⽤了指定模块,使⽤就会报错
"no-return-assign": 1,//return 语句中不能有赋值表达式
"no-script-url": 0,//禁⽌使⽤javascript:void(0)
"no-self-compare": 2,//不能⽐较⾃身
"no-sequences": 0,//禁⽌使⽤逗号运算符
"no-shadow": 2,//外部作⽤域中的变量不能与它所包含的作⽤域中的变量或参数同名
"no-shadow-restricted-names": 2,//严格模式中规定的限制标识符不能作为声明时的变量名使⽤
"no-spaced-func": 2,//函数调⽤时 函数名与()之间不能有空格
"no-sparse-arrays": 2,//禁⽌稀疏数组, [1,,2]
"no-sync": 0,//nodejs 禁⽌同步⽅法
"no-ternary": 0,//禁⽌使⽤三⽬运算符
"no-trailing-spaces": 1,//⼀⾏结束后⾯不要有空格
"no-this-before-super": 0,//在调⽤super()之前不能使⽤this或super
"no-throw-literal": 2,//禁⽌抛出字⾯量错误 throw "error";
"no-undef": 1,//不能有未定义的变量
"no-undef-init": 2,//变量初始化时不能直接给它赋值为undefined
"no-undefined": 2,//不能使⽤undefined
"no-unexpected-multiline": 2,//避免多⾏表达式
"no-underscore-dangle": 1,//标识符不能以_开头或结尾
"no-unneeded-ternary": 2,//禁⽌不必要的嵌套 var isYes = answer === 1 ? true : false;
"no-unreachable": 2,//不能有⽆法执⾏的代码
"no-unused-expressions": 2,//禁⽌⽆⽤的表达式
"no-unused-vars": [2, {"vars": "all", "args": "after-used"}],//不能有声明后未被使⽤的变量或参数
"no-use-before-define": 2,//未定义前不能使⽤
"no-useless-call": 2,//禁⽌不必要的call和apply
"no-void": 2,//禁⽤void操作符
"no-var": 0,//禁⽤var,⽤let和const代替
"no-warning-comments": [1, { "terms": ["todo", "fixme", "xxx"], "location": "start" }],//不能有警告备
"no-with": 2,//禁⽤with
"array-bracket-spacing": [2, "never"],//是否允许⾮空数组⾥⾯有多余的空格
"arrow-parens": 0,//箭头函数⽤⼩括号括起来
"arrow-spacing": 0,//=>的前/后括号
"accessor-pairs": 0,//在对象中使⽤getter/setter
"block-scoped-var": 0,//块语句中使⽤var
"brace-style": [1, "1tbs"],//⼤括号⻛格
"callback-return": 1,//避免多次调⽤回调什么的
"camelcase": 2,//强制驼峰法命名
"comma-dangle": [2, "never"],//对象字⾯量项尾不能有逗号
"comma-spacing": 0,//逗号前后的空格
"comma-style": [2, "last"],//逗号⻛格,换⾏时在⾏⾸还是⾏尾
"complexity": [0, 11],//循环复杂度
"computed-property-spacing": [0, "never"],//是否允许计算后的键名什么的
"consistent-return": 0,//return 后⾯是否允许省略
"consistent-this": [2, "that"],//this别名
"constructor-super": 0,//⾮派⽣类不能调⽤super,派⽣类必须调⽤super
"curly": [2, "all"],//必须使⽤ if(){} 中的{}
"default-case": 2,//switch语句最后必须有default
"dot-location": 0,//对象访问符的位置,换⾏的时候在⾏⾸还是⾏尾
"dot-notation": [0, { "allowKeywords": true }],//避免不必要的⽅括号
"eol-last": 0,//⽂件以单⼀的换⾏符结束
"eqeqeq": 2,//必须使⽤全等
"func-names": 0,//函数表达式必须有名字
"func-style": [0, "declaration"],//函数⻛格,规定只能使⽤函数声明/函数表达式
"generator-star-spacing": 0,//⽣成器函数*的前后空格
"guard-for-in": 0,//for in循环要⽤if语句过滤
"handle-callback-err": 0,//nodejs 处理错误
"id-length": 0,//变量名⻓度
"indent": [2, 4],//缩进⻛格
"init-declarations": 0,//声明时必须赋初值
"key-spacing": [0, { "beforeColon": false, "afterColon": true }],//对象字⾯量中冒号的前后空格
"lines-around-comment": 0,//⾏前/⾏后备注
"max-depth": [0, 4],//嵌套块深度
"max-len": [0, 80, 4],//字符串最⼤⻓度
"max-nested-callbacks": [0, 2],//回调嵌套深度
"max-params": [0, 3],//函数最多只能有3个参数
"max-statements": [0, 10],//函数内最多有⼏个声明
"new-cap": 2,//函数名⾸⾏⼤写必须使⽤new⽅式调⽤,⾸⾏⼩写必须⽤不带new⽅式调⽤
"new-parens": 2,//new时必须加⼩括号
"newline-after-var": 2,//变量声明后是否需要空⼀⾏
"object-curly-spacing": [0, "never"],//⼤括号内是否允许不必要的空格
"object-shorthand": 0,//强制对象字⾯量缩写语法
"one-var": 1,//连续声明
"operator-assignment": [0, "always"],//赋值运算符 += -=什么的
"operator-linebreak": [2, "after"],//换⾏时运算符在⾏尾还是⾏⾸
"padded-blocks": 0,//块语句内⾏⾸⾏尾是否要空⾏
"prefer-const": 0,//⾸选const
"prefer-spread": 0,//⾸选展开运算
"prefer-reflect": 0,//⾸选Reflect的⽅法
"quotes": [1, "single"],//引号类型 `` "" ''
"quote-props":[2, "always"],//对象字⾯量中的属性名是否强制双引号
"radix": 2,//parseInt必须指定第⼆个参数
"id-match": 0,//命名检测
"require-yield": 0,//⽣成器函数必须有yield
"semi": [2, "always"],//语句强制分号结尾
"semi-spacing": [0, {"before": false, "after": true}],//分号前后空格
"sort-vars": 0,//变量声明时排序
"space-after-keywords": [0, "always"],//关键字后⾯是否要空⼀格
"space-before-blocks": [0, "always"],//不以新⾏开始的块{前⾯要不要有空格
"space-before-function-paren": [0, "always"],//函数定义时括号前⾯要不要有空格
"space-in-parens": [0, "never"],//⼩括号⾥⾯要不要有空格
"space-infix-ops": 0,//中缀操作符周围要不要有空格
"space-return-throw-case": 2,//return throw case后⾯要不要加空格
"space-unary-ops": [0, { "words": true, "nonwords": false }],//⼀元运算符的前/后要不要加空格
"spaced-comment": 0,//注释⻛格要不要有空格什么的
"strict": 2,//使⽤严格模式
"use-isnan": 2,//禁⽌⽐较时使⽤NaN,只能⽤isNaN()
"valid-jsdoc": 0,//jsdoc规则
"valid-typeof": 2,//必须使⽤合法的typeof的值
"vars-on-top": 2,//var必须放在作⽤域顶部
"wrap-iife": [2, "inside"],//⽴即执⾏函数表达式的⼩括号⻛格
"wrap-regex": 0,//正则表达式字⾯量⽤⼩括号包起来
"yoda": [2, "never"]//禁⽌尤达条件

例子

module.exports = {
     // 解析语法
     "parser": "@typescript-eslint/parser",
     // 指定脚本运⾏环境
     "env": {
         "browser": true,
         "es6": true,
         "node": true,
         "commonjs": true,
         "jsx-control-statements/jsx-control-statements": true
     },
     "extends": [
         "plugin:@typescript-eslint/recommended",
         "plugin:react/recommended",
         "plugin:jsx-control-statements/recommended",
     ],
     "root": true,
     // 脚本在执⾏期间访问的额外的全局变量
     // 当访问当前源⽂件内未定义的变量时,no-undef规则将发出警告
     // 所以需要定义这些额外的全局变量
     "globals": {
         "Atomics": "readonly",
         "SharedArrayBuffer": "readonly",
         "OnlySVG": true,
         "monitor": true,
         "CanvasRender": true,
     },
     // 指定解析器选项
     "parserOptions": {
         // 使⽤额外的语⾔特性
         "ecmaFeatures": {
         "expperimentalObjectRestSpread": true,
         "jsx": true,
         "modules": true
     },
     // 启⽤ES2018语法⽀持
     "ecmaVersion": 2018,
     // module表示ECMAScript模块
     "sourceType": "module"
     },
     // 指定需要的插件
     "plugins": [
         "@typescript-eslint",
         "jsx-control-statements",
         "react"
     ],
     // 启⽤的规则及其各⾃的错误级别
     "rules": {
         "@typescript-eslint/no-explicit-any": "off",
         "@typescript-eslint/explicit-member-accessibility": "off",
         "@typescript-eslint/no-var-requires": "off",
         "@typescript-eslint/explicit-function-return-type": "off",
         "@typescript-eslint/indent": [
             "error",
             4,
             { VariableDeclarator: 4, SwitchCase: 1 }
         ],
         "@typescript-eslint/no-unused-vars": 0,
         "@typescript-eslint/interface-name-prefix": 0,
         // React相关校验规则
         "react/jsx-indent": [2, 4],
         "react/jsx-no-undef": [2, { allowGlobals: true }],
         "jsx-control-statements/jsx-use-if-tag": 0,
         // 设置了 setter ,必须相应设置 getter ,反之不必须
         "accessor-pairs": 2,
         // 数组⽅括号前后的换⾏符使⽤规则
         // @off 不关⼼
         "array-bracket-newline": 0,
         // 数组⽅括号前后的空格使⽤规则
         // @off 不关⼼
         "array-bracket-spacing": 0,
         // 数组的 map、filter、sort 等⽅法,回调函数必须有返回值
         "array-callback-return": 2,
         // 每个数组项是否独占⼀⾏
         // @off 不关⼼
         "array-element-newline": 0,
         // 箭头函数的书写规则
         // @off 不限制
         "arrow-body-style": 0,
         // 箭头函数的圆括号使⽤规则
         // @off 不限制
         "arrow-parens": 0,
         // 箭头函数的空格使⽤规则
         // @off 不限制
         "arrow-spacing": 0,
         // 不能在块外使⽤块作⽤域内 var 定义的变量
         "block-scoped-var": 2,
         // 代码块花括号前后的空格规则
         // @off 不关⼼
         "block-spacing": 0,
         // if else 的花括号换⾏规则
         // @off 不关⼼
         "brace-style": 0,
         // callback 之后必须⽴即 return
         // @off 没必要
         "callback-return": 0,
         // 变量名必须使⽤驼峰式
         // @off 暂不限制
         "camelcase": 0,
         // 注释的⾸字⺟应该⼤写
         // @off 没必要
         "capitalized-comments": 0,
         // 对象的最后⼀项后⾯是否写逗号
         // @off 此项⽬不关⼼
         // @fixable 对于 PC 项⽬考虑兼容性时需要设置
         "comma-dangle": 0,
         // 逗号前后是否有空格
         // @off 不关⼼
         "comma-spacing": 0,
         // 逗号写在⾏⾸还是⾏尾
         // @off 不关⼼
         "comma-style": 0,
         // 禁⽌函数 if ... else if ... else 的复杂度超过 20
         "complexity": 2,
         // 使⽤⽅括号访问对象属性时,⽅括号前后的空格规则
         // @off 不关⼼
         "computed-property-spacing": 0,
         // 禁⽌函数在不同条件下返回不同类型的值
         // @off 有时候会希望通过参数获取不同类型的返回值
         "consistent-return": 0,
         // this 的别名规则,只允许 self 或 that
         "consistent-this": [2, "self", "that"],
         // 构造函数中必须调⽤ super
         // @off 没必要
         "constructor-super": 0,
         // if 后必须包含 { ,单⾏ if 除外
         "curly": [2, "multi-line", "consistent"],
         // switch 语句必须包含 default
         "default-case": 2,
         // 链式操作时,点的位置,是在上⼀⾏结尾还是下⼀⾏开头
         // @off 不关⼼
         "dot-location": 0,
         // ⽂件最后必须有空⾏
         // @off 不限制
         "eol-last": 0,
         // 必须使⽤ === 和 !== ,和 null 对⽐时除外
         "eqeqeq": [2, "always", { "null": "ignore" }],
         // for 循环不得因⽅向错误造成死循环
         "for-direction": 2,
         // 执⾏函数的圆括号前后的空格规则
         // @off 不关⼼
         "func-call-spacing": 0,
         // 把函数赋给变量或对象属性时,函数名和变量名或对象属性名必须⼀致
         // @off 不限制
         "func-name-matching": 0,
         // 不允许匿名函数
         // @off 不限制
         "func-names": 0,
         // 必须只使⽤函数申明或只使⽤函数表达式
         // @off 不限制
         "func-style": 0,
         // generator 的 * 前后空格使⽤规则
         // @off 不限制
         "generator-star-spacing": 0,
         // getter 必须有返回值,允许返回 undefined
         "getter-return": [2, { allowImplicit: true }],
         // require 必须在全局作⽤域下
         // @off 条件加载很常⻅
         "global-require": 0,
         // for in 时需检测 hasOwnProperty
         "guard-for-in": 2,
         // callback 中的 err、error 参数和变量必须被处理
         "handle-callback-err": 2,
         // id ⿊名单
         // @off 暂时没有
         "id-blacklist": 0,
         // 变量名⻓度限制
         // @off ⻓度不是重点,清晰易读才是关键
         "id-length": 0,
         // 限制变量名必须匹配指定的正则表达式
         // @off 没必要限制变量名
         "id-match": 0,
         // 缩进使⽤ tab 还是空格
         // @off 不关⼼
         "indent": 0,
         // 变量必须在定义的时候赋值
         // @off 先定义后赋值很常⻅
         "init-declarations": 0,
         // jsx 语法中,属性的值必须使⽤双引号
         "jsx-quotes": [1, "prefer-single"],
         // 对象字⾯量冒号前后的空格使⽤规则
         // @off 不关⼼
         "key-spacing": 0,
         // 关键字前后必须有空格
         "keyword-spacing": 2,
         // 换⾏符使⽤规则
         // @off 不关⼼
         "linebreak-style": 0,
         // 单⾏注释必须写在前⼀⾏还是⾏尾
         // @off 不限制
         "line-comment-position": 0,
         // 注释前后是否要空⼀⾏
         // @off 不限制
         "lines-around-comment": 0,
         // 最⼤块嵌套深度为 5 层
         "max-depth": [2, 5],
         // 限制单⾏代码的⻓度
         // @off 不限制
         "max-len": 0,
         // 限制单个⽂件最⼤⾏数
         // @off 不限制
         "max-lines": 0,
         // 最⼤回调深度为 3 层
         "max-nested-callbacks": [2, 3],
         // 函数的形参不能多于8个
         "max-params": [2, 8],
         // 限制⼀⾏中的语句数量
         // @off 没必要限制
         "max-statements-per-line": 0,
         // 限制函数块中的语句数量
         // @off 没必要限制
         "max-statements": 0,
         // 三元表达式的换⾏规则
         // @off 不限制
         "multiline-ternary": 0,
         // new关键字后类名应⾸字⺟⼤写
         "new-cap": [2, {
         "capIsNew": false, // 允许⼤写开头的函数直接执⾏
         }],
         // new 关键字后类应包含圆括号
         "new-parens": 2,
         // 链式调⽤是否要换⾏
         // @off 不限制
         "newline-per-chained-call": 0,
         // 禁⽌ alert,提醒开发者,上线时要去掉
         "no-alert": 1,
         // 禁⽌使⽤ Array 构造函数,使⽤ Array(num) 直接创建⻓度为 num 的数组时可以
         "no-array-constructor": 2,
         // 禁⽌将 await 写在循环⾥
         "no-await-in-loop": 2,
         // 禁⽌位运算
         // @off 不限制
         "no-bitwise": 0,
         // 禁⽌在 Node.js 中直接调⽤ Buffer 构造函数
         "no-buffer-constructor": 2,
         // 禁⽌使⽤ arguments.caller 和 arguments.callee
         "no-caller": 2,
         // switch的条件中出现 var、let、const、function、class 等关键字,必须使⽤花括号把内容括起来
         "no-case-declarations": 2,
         // catch中不得使⽤已定义的变量名
         "no-catch-shadow": 2,
         // class定义的类名不得与其它变量重名
         "no-class-assign": 2,
         // 禁⽌与 -0 做⽐较
         "no-compare-neg-zero": 2,
         // 禁⽌在 if、for、while 中出现赋值语句,除⾮⽤圆括号括起来
         "no-cond-assign": [2, "except-parens"],
         // 禁⽌出现难以理解的箭头函数,除⾮⽤圆括号括起来
         "no-confusing-arrow": [2, { "allowParens": true }],
         // 禁⽌使⽤ console,提醒开发者,上线时要去掉
         "no-console": 1,
         // 禁⽌使⽤常量作为判断条件
         "no-constant-condition": [2, { "checkLoops": false }],
         // 禁⽌对 const 定义重新赋值
         "no-const-assign": 2,
         // 禁⽌ continue
         // @off 很常⽤
         "no-continue": 0,
         // 禁⽌正则表达式中出现 Ctrl 键的 ASCII 表示,即/\x1f/
         "no-control-regex": 2,
         // 禁⽌ debugger 语句,提醒开发者,上线时要去掉
         "no-debugger": 1,
         // 禁⽌对变量使⽤ delete 关键字,删除对象的属性不受限制
         "no-delete-var": 2,
         // 禁⽌在正则表达式中出现形似除法操作符的开头,如 let a = /=foo/
         // @off 有代码⾼亮的话,在阅读这种代码时,也完全不会产⽣歧义或理解上的困难
         "no-div-regex": 0,
         // 函数参数禁⽌重名
         "no-dupe-args": 2,
         // 禁⽌对象出现重名键值
         "no-dupe-keys": 2,
         // 类⽅法禁⽌重名
         "no-dupe-class-members": 2,
         // 禁⽌ switch 中出现相同的 case
         "no-duplicate-case": 2,
         // 禁⽌重复 import
         "no-duplicate-imports": 2,
         // 禁⽌出现 if (cond) { return a } else { return b },应该写为 if (cond) { return a } return b
         // @off 有时前⼀种写法更清晰易懂
         "no-else-return": 0,
         // 正则表达式中禁⽌出现空的字符集[]
         "no-empty-character-class": 2,
         // 禁⽌空的 function
         // 包含注释的情况下允许
         "no-empty-function": 2,
         // 禁⽌解构中出现空 {} 或 []
         "no-empty-pattern": 2,
         // 禁⽌出现空代码块
         "no-empty": [2, { "allowEmptyCatch": true }],
         // 禁⽌ == 和 != 与 null 做⽐较,必须⽤ === 或 !==
         // @off ⾮严格相等可以同时判断 null 和 undefined
         "no-eq-null": 0,
         // 禁⽌使⽤ eval
         "no-eval": 2,
         // catch 定义的参数禁⽌赋值
         "no-ex-assign": 2,
         // 禁⽌扩展原⽣对象
         "no-extend-native": [2, { "exceptions": ["Array", "Object"] }],
         // 禁⽌额外的 bind
         "no-extra-bind": 2,
         // 禁⽌额外的布尔值转换
         "no-extra-boolean-cast": 2,
         // 禁⽌额外的 label
         "no-extra-label": 2,
         // 禁⽌额外的括号,仅针对函数体
         "no-extra-parens": [2, "functions"],
         // 禁⽌额外的分号
         "no-extra-semi": 2,
         // 每⼀个 switch 的 case 都需要有 break, return 或 throw
         // 包含注释的情况下允许
         "no-fallthrough": [2, { "commentPattern": "." }],
         // 不允许使⽤ 2. 或 .5 来表示数字,需要⽤ 2、2.0、0.5 的格式
         "no-floating-decimal": 2,
         // 禁⽌对函数声明重新赋值
         "no-func-assign": 2,
         // 禁⽌对全局变量赋值
         "no-global-assign": 2,
         // 禁⽌使⽤隐式类型转换
         "no-implicit-coercion": [2, {
         "allow": ["+", "!!"] // 允许 + 转数值 "" + 转字符串和 !! 转布尔值
         }],
         // 禁⽌在 setTimeout 和 setInterval 中传⼊字符串,因会触发隐式 eval
         "no-implied-eval": 2,
         // 禁⽌隐式定义全局变量
         "no-implicit-globals": 2,
         // 禁⽌⾏内注释
         // @off 很常⽤
         "no-inline-comments": 0,
         // 禁⽌在块作⽤域内使⽤ var 或函数声明
         "no-inner-declarations": [2, "both"],
         // 禁⽌使⽤⾮法的正则表达式
         "no-invalid-regexp": 2,
         // 禁⽌在类之外的地⽅使⽤ this
         // @off this 的使⽤很灵活,事件回调中可以表示当前元素,函数也可以先⽤ this,等以后被调⽤的时候再 call
         "no-invalid-this": 0,
         // 禁⽌使⽤不规范空格
         "no-irregular-whitespace": [2, {
         "skipStrings": true, // 允许在字符串中使⽤
         "skipComments": true, // 允许在注释中使⽤
         "skipRegExps": true, // 允许在正则表达式中使⽤
         "skipTemplates": true, // 允许在模板字符串中使⽤
         }],
         // 禁⽌使⽤ __iterator__
         "no-iterator": 2,
         // label 不得与已定义的变量重名
         "no-label-var": 2,
         // 禁⽌使⽤ label
         // @off 禁⽌了将很难 break 多重循环和多重 switch
         "no-labels": 0,
         // 禁⽌使⽤⽆效的块作⽤域
         "no-lone-blocks": 2,
         // 禁⽌ else 中只有⼀个单独的 if
         // @off 单独的 if 可以把逻辑表达的更清楚
         "no-lonely-if": 0,
         // 禁⽌ for (var i) { function() { use i } },使⽤ let 则可以
         "no-loop-func": 2,
         // 禁⽌魔法数字
         "no-magic-numbers": 0,
         // 禁⽌使⽤混合的逻辑判断,必须把不同的逻辑⽤圆括号括起来
         "no-mixed-operators": [2, {
             "groups": [
                 ["&&", "||"]
             ]
         }],
         // 相同类型的 require 必须放在⼀起
         // @off 不限制
         "no-mixed-requires": 0,
         // 禁⽌混⽤空格和 tab 来做缩进,必须统⼀
         "no-mixed-spaces-and-tabs": 2,
         // 禁⽌连等赋值
         "no-multi-assign": 2,
         // 禁⽌使⽤连续的空格
         "no-multi-spaces": 2,
         // 禁⽌使⽤ \ 来定义多⾏字符串,统⼀使⽤模板字符串来做
         "no-multi-str": 2,
         // 连续空⾏的数量限制
         "no-multiple-empty-lines": [2, {
             max: 3, // ⽂件内最多连续 3 个
             maxEOF: 1, // ⽂件末尾最多连续 1 个
             maxBOF: 1 // ⽂件头最多连续 1 个
         }],
         // 禁⽌ if 中出现否定表达式 !==
         // @off 否定的表达式可以把逻辑表达的更清楚
         "no-negated-condition": 0,
         // 禁⽌嵌套的三元表达式
         // @off 没有必要限制
         "no-nested-ternary": 0,
         // 禁⽌ new Function
         // @off 有时会⽤它来解析⾮标准格式的 JSON 数据
         "no-new-func": 0,
         // 禁⽌使⽤ new Object
         "no-new-object": 2,
         // 禁⽌使⽤ new require
         "no-new-require": 2,
         // 禁⽌使⽤ new Symbol
         "no-new-symbol": 2,
         // 禁⽌ new Boolean、Number 或 String
         "no-new-wrappers": 2,
         // 禁⽌ new ⼀个类⽽不存储该实例
         "no-new": 2,
         // 禁⽌把原⽣对象 Math、JSON、Reflect 当函数使⽤
         "no-obj-calls": 2,
         // 禁⽌使⽤⼋进制转义符
         "no-octal-escape": 2,
         // 禁⽌使⽤0开头的数字表示⼋进制
         "no-octal": 2,
         // 禁⽌使⽤ __dirname + "file" 的形式拼接路径,应该使⽤ path.join 或 path.resolve 来代替
         "no-path-concat": 2,
         // 禁⽌对函数的参数重新赋值
         "no-param-reassign": 2,
         // 禁⽌ ++ 和 --
         // @off 很常⽤
         "no-plusplus": 0,
         // 禁⽌使⽤ process.env.NODE_ENV
         // @off 使⽤很常⻅
         "no-process-env": 0,
         // 禁⽌使⽤ process.exit(0)
         // @off 使⽤很常⻅
         "no-process-exit": 0,
         // 禁⽌使⽤ hasOwnProperty, isPrototypeOf 或 propertyIsEnumerable
         // @off 与 guard-for-in 规则冲突,且没有必要
         "no-prototype-builtins": 0,
         // 禁⽌使⽤ __proto__
         "no-proto": 2,
         // 禁⽌重复声明
         "no-redeclare": 2,
         // 禁⽌在正则表达式中出现连续空格
         "no-regex-spaces": 2,
         // 禁⽌特定的全局变量
         // @off 暂时没有
         "no-restricted-globals": 0,
         // 禁⽌ import 特定的模块
         // @off 暂时没有
         "no-restricted-imports": 0,
         // 禁⽌使⽤特定的模块
         // @off 暂时没有
         "no-restricted-modules": "off",
         // 禁⽌特定的对象属性
         // @off 暂时没有
         "no-restricted-properties": 0,
         // 禁⽌使⽤特定的语法
         // @off 暂时没有
         "no-restricted-syntax": 0,
         // 禁⽌在return中赋值
         "no-return-assign": 2,
         // 禁⽌在 return 中使⽤ await
         "no-return-await": 2,
         // 禁⽌ location.href = "javascript:void"
         "no-script-url": 2,
         // 禁⽌将⾃⼰赋值给⾃⼰
         "no-self-assign": 2,
         // 禁⽌⾃⼰与⾃⼰作⽐较
         "no-self-compare": 2,
         // 禁⽌逗号操作符
         "no-sequences": 2,
         // 禁⽌使⽤保留字作为变量名
         "no-shadow-restricted-names": 2,
         // 禁⽌在嵌套作⽤域中出现重名的定义,如 let a; function b() { let a }
         "no-shadow": 2,
         // 禁⽌数组中出现连续逗号
         "no-sparse-arrays": 2,
         // 禁⽌使⽤ node 中的同步的⽅法,⽐如 fs.readFileSync
         // @off 使⽤很常⻅
         "no-sync": 0,
         // 禁⽌使⽤ tabs
         // @off 不限制
         "no-tabs": 0,
         // 禁⽌普通字符串中出现模板字符串语法
         "no-template-curly-in-string": 2,
         // 禁⽌三元表达式
         // @off 很常⽤
         "no-ternary": 0,
         // 禁⽌在构造函数的 super 之前使⽤ this
         "no-this-before-super": 2,
         // 禁⽌ throw 字⾯量,必须 throw ⼀个 Error 对象
         "no-throw-literal": 2,
         // 禁⽌⾏尾空格
         "no-trailing-spaces": [2, {
             "skipBlankLines": true, // 不检查空⾏
             "ignoreComments": true // 不检查注释
         }],
         // 禁⽌将 undefined 赋值给变量
         "no-undef-init": 2,
         // 禁⽌访问未定义的变量或⽅法
         "no-undef": 2,
         // 禁⽌使⽤ undefined,如需判断⼀个变量是否为 undefined,请使⽤ typeof a === "undefined"
         "no-undefined": 2,
         // 禁⽌变量名中使⽤下划线
         // @off 暂不限制
         "no-underscore-dangle": 0,
         // 禁⽌出现难以理解的多⾏代码
         "no-unexpected-multiline": 2,
         // 循环体内必须对循环条件进⾏修改
         "no-unmodified-loop-condition": 2,
         // 禁⽌不必要的三元表达式
         "no-unneeded-ternary": [2, { "defaultAssignment": false }],
         // 禁⽌出现不可到达的代码,如在 return、throw 之后的代码
         "no-unreachable": 2,
         // 禁⽌在finally块中出现 return、throw、break、continue
         "no-unsafe-finally": 2,
         // 禁⽌出现不安全的否定,如 for (!key in obj} {},应该写为 for (!(key in obj)} {}
         "no-unsafe-negation": 2,
         // 禁⽌出现⽆⽤的表达式
         "no-unused-expressions": [2,
             {
                 "allowShortCircuit": true, // 允许使⽤ a() || b 或 a && b()
                 "allowTernary": true, // 允许在表达式中使⽤三元运算符
                 "allowTaggedTemplates": true, // 允许标记模板字符串
             }
         ],
         // 禁⽌定义不使⽤的 label
         "no-unused-labels": 2,
         // 禁⽌定义不使⽤的变量
         "no-unused-vars": [2,
             {
                 "vars": "all", // 变量定义必须被使⽤
                 "args": "none", // 对于函数形参不检测
                 "ignoreRestSiblings": true, // 忽略剩余⼦项 fn(...args),{a, b, ...coords}
                 "caughtErrors": "none", // 忽略 catch 语句的参数使⽤
             }
         ],
         // 禁⽌在变量被定义之前使⽤它
         "no-use-before-define": [2,
             {
                 "functions": false, // 允许函数在定义之前被调⽤
                 "classes": false, // 允许类在定义之前被引⽤
             }
         ],
         // 禁⽌不必要的 call 和 apply
         "no-useless-call": 2,
         // 禁⽌使⽤不必要计算的key,如 var a = { ["0"]: 0 }
         "no-useless-computed-key": 2,
         // 禁⽌不必要的字符串拼接
         "no-useless-concat": 2,
         // 禁⽌⽆⽤的构造函数
         "no-useless-constructor": 2,
         // 禁⽌⽆⽤的转义
         "no-useless-escape": 2,
         // 禁⽌⽆效的重命名,如 import {a as a} from xxx
         "no-useless-rename": 2,
         // 禁⽌没有必要的 return
         // @off 没有必要限制
         "no-useless-return": 0,
         // 禁⽌使⽤ var,必须⽤ let 或 const
         "no-var": 2,
         // 禁⽌使⽤void
         "no-void": 2,
         // 禁⽌注释中出现 TODO 或 FIXME,⽤这个来提醒开发者,写了 TODO 就⼀定要做完
         "no-warning-comments": 1,
         // 禁⽌属性前出现空格,如 foo. bar()
         "no-whitespace-before-property": 2,
         // 禁⽌ with
         "no-with": 2,
         // 禁⽌ if 语句在没有花括号的情况下换⾏
         "nonblock-statement-body-position": 2,
         // 定义对象的花括号前后是否要加空⾏
         // @off 不关⼼
         "object-curly-newline": 0,
         // 定义对象的花括号前后是否要加空格
         // @off 不关⼼
         "object-curly-spacing": 0,
         // 对象每个属性必须独占⼀⾏
         // @off 不限制
         "object-property-newline": 0,
         // obj = { a: a } 必须转换成 obj = { a }
         // @off 没必要
         "object-shorthand": 0,
         // 每个变量声明必须独占⼀⾏
         // @off 有 one-var 就不需要此规则了
         "one-var-declaration-per-line": 0,
         // 是否允许使⽤逗号⼀次声明多个变量
         "one-var": [2, {
         "const": "never" // 所有 const 声明必须独占⼀⾏,不允许⽤逗号定义多个
         }],
         // 必须使⽤ x = x + y ⽽不是 x += y
         // @off 没必要限制
         "operator-assignment": 0,
         // 断⾏时操作符位于⾏⾸还是⾏尾
         // @off 不关⼼
         "operator-linebreak": 0,
         // 代码块⾸尾必须要空⾏
         // @off 没必要限制
         "padded-blocks": 0,
         // 限制语句之间的空⾏规则,⽐如变量定义完之后必须要空⾏
         // @off 没必要限制
         "padding-line-between-statements": 0,
         // 必须使⽤箭头函数作为回调
         // @off 没必要
         "prefer-arrow-callback": 0,
         // 声明后不再修改的变量必须使⽤ const
         // @off 没必要
         "prefer-const": 0,
         // 必须使⽤解构
         // @off 没必要
         "prefer-destructuring": 0,
         // 必须使⽤ 0b11111011 ⽽不是 parseInt("111110111", 2)
         // @off 没必要
         "prefer-numeric-literals": 0,
         // promise 的 reject 中必须传⼊ Error 对象,⽽不允许使⽤字⾯量
         "prefer-promise-reject-errors": 2,
         // 必须使⽤解构 ...args 来代替 arguments
         "prefer-rest-params": 2,
         // 必须使⽤ func(...args) 来代替 func.apply(args)
         // @off 没必要
         "prefer-spread": 0,
         // 必须使⽤模板字符串来代替字符串拼接
         // @off 不限制
         "prefer-template": 0,
         // 字符串必须使⽤单引号
         "quotes": [2, "single", {
             "avoidEscape": true, // 允许包含单引号的字符串使⽤双引号
             "allowTemplateLiterals": true, // 允许使⽤模板字符串
         }],
         // 对象字⾯量的键名禁⽌⽤引号括起来
         // @off 没必要限制
         "quote-props": 0,
         // parseInt⽅法必须传进制参数
         "radix": 2,
         // async 函数中必须存在 await 语句
         // @off async function 中没有 await 的写法很常⻅,⽐如 koa 的示例中就有这种⽤法
         "require-await": 0,
         // 必须使⽤ jsdoc ⻛格的注释
         // @off 暂不考虑开启
         "require-jsdoc": 0,
         // generator 函数内必须有 yield
         "require-yield": 2,
         // ...后⾯不允许有空格
         "rest-spread-spacing": [2, "never"],
         // 分号前后的空格规则
         // @off 不限制
         "semi-spacing": 0,
         // 禁⽌⾏⾸出现分号
         "semi-style": [2, "last"],
         // ⾏尾必须使⽤分号结束
         "semi": 2,
         // imports 必须排好序
         // @off 没必要限制
         "sort-imports": 0,
         // 对象字⾯量的键名必须排好序
         // @off 没必要限制
         "sort-keys": 0,
         // 变量声明必须排好序
         // @off 没必要限制
         "sort-vars": 0,
         // function 等的花括号之前是否使⽤空格
         // @off 不关⼼
         "space-before-blocks": 0,
         // function 的圆括号之前是否使⽤空格
         // @off 不关⼼
         "space-before-function-paren": 0,
         // 圆括号内的空格使⽤规则
         // @off 不关⼼
         "space-in-parens": 0,
         // 操作符前后要加空格
         "space-infix-ops": 2,
         // new, delete, typeof, void, yield 等表达式前后必须有空格,-, +, --, ++, !, !! 等表达式前后不许有
         "space-unary-ops": [2, {
             "words": true,
             "nonwords": false,
         }],
         // 注释的斜线和星号后要加空格
         "spaced-comment": [2, "always", {
             "block": {
                 exceptions: ["*"],
                 balanced: true
             }
         }],
         // 禁⽤严格模式,禁⽌在任何地⽅出现 "use strict"
         "strict": [2, "never"],
         // switch 中冒号前后的空格规则
         // @off 不关⼼
         "switch-colon-spacing": 0,
         // 创建 Symbol 的时候必须传⼊描述
         "symbol-description": 2,
         // 模板字符串 ${} 前后的空格规则
         // @off 不限制
         "template-curly-spacing": 0,
         // 模板字符串前后的空格规则
         // @off 不限制
         "template-tag-spacing": 0,
         // 所有⽂件头禁⽌出现 BOM
         "unicode-bom": 2,
         // 禁⽌直接对 NaN 进⾏判断,必须使⽤ isNaN
         "use-isnan": 2,
         // 注释必须符合 jsdoc 的规范
         // @off 暂不考虑开启
         "valid-jsdoc": 0,
         // typeof 判断条件只能是 "undefined", "object", "boolean", "number", "string", "function" 或 "
         "valid-typeof": 2,
         // var 必须在作⽤域的最前⾯
         // @off var 不在最前⾯也是很常⻅的⽤法
         "vars-on-top": 0,
         // ⾃执⾏函数必须使⽤圆括号括起来,如 (function(){do something...})()
         "wrap-iife": [2, "inside"],
         // 正则表达式必须⽤圆括号括起来
         // @off 不限制
         "wrap-regex": 0,
         // yield 的 * 前后空格规则
         // @off 不限制
         "yield-star-spacing": 0,
         // 禁⽌Yoda格式的判断条件,如 if (true === a),应使⽤ if (a === true)
         "yoda": 2,
         }
};

875571
https://www.w3cplus.com/javascript/webpack-config-part1.html

Webpack 打包优化之体积篇
Webpack 打包优化之速度篇
(webpack系列二)webpack打包优化探索

Webpack按需打包Lodash的几种方式

webpack 打包JS 的运行原理

优化

使用可视化图表对 Webpack 2 的编译与打包进行统计分析

全局引入lodash,报错

index.js(main.js)

import _                from 'lodash';

// 设置lodash 全局

window._ = _;


warning  '_' is not defined  no-undef

https://stackoverflow.com/questions/45317154/error-is-not-defined-no-undef

.eslintrc

"globals" : {
    "$axios": false,
    "$store": false,
    "APIs": false,
    "__PROJECTDIR__": false,
    "_": true
  },


ESLint配置清单

ESLint官方提供的一份标准配置
阿里eslint-config-ali
腾讯AlloyTeamAlloyTeam ESLint 配置指南
Airbnb JavaScript Style Guide