vue项⽬中ESLint说明
eslint配置⽅式有两种:
⼀、注释配置:
使⽤js注释来直接嵌⼊ESLint配置信息到⼀个⽂件⾥
配置⽂件:使⽤⼀个js,JSON或者YAML⽂件来给整个⽬录和它的⼦⽬录指定配置信息。这些配置可以写在⼀个⽂件名为.eslintrc.*的⽂件或者在package.json⽂件⾥的eslintConfig项⾥,这两种⽅式ESLint都会⾃动寻找然后读取,或者你也可以在命令⾏⾥指定⼀个配置⽂件。
有⼏种东西是可以配置的:
⼆、环境:
你的脚本会在哪种环境下运⾏。每个环境带来了⼀组特定的预定义的全局变量。
全局变量:脚本运⾏期间会访问额外的全局变量。
规则:使⽤那些规则,并且规则的等级是多少。
我们这⾥使⽤配置⽂件.eslintrc.js来配置,它导出⼀个模块供ESLint识别。
// /docs/ur-guide/configuring
root: true,
parr: 'babel-eslint',//解析器,这⾥我们使⽤babel-eslint
parrOptions: {
sourceType: 'module'//类型为module,因为代码使⽤了使⽤了ECMAScript模块
},
env: {
browr: true,//预定义的全局变量,这⾥是浏览器环境
},
/
/ /feross/standard/blob/master/RULES.md#javascript-standard-style
//extends: 'standard', //扩展,可以通过字符串或者⼀个数组来扩展规则
// required to lint *.vue files
plugins: [
'html' //插件,此插件⽤于识别⽂件中的js代码,没有MIME类型标识没有script标签也可以识别到,因此拿来识别.vue⽂件中的js代码
],
// add your custom rules here
'rules': {
//这⾥写⾃定义规则
}
}
ESLint的规则有三种级别:
1. "off"或者0,不启⽤这个规则
2. "warn"或者1,出现问题会有警告
3. "error"或者2,出现问题会报错
有时候代码⾥有些特殊情况需要我们在某⼀⾏或者某⼏⾏关闭ESLint检测,可以使⽤注释:
下⾯的代码会关闭所有规则
/* eslint-disable */
alert('foo');
/* eslint-enable */
下⾯的代码在某⼀⾏关闭指定的规则
alert('foo'); // eslint-disable-line no-alert
/
/ eslint-disable-next-line no-alert
alert('foo');
常⽤规则:
'rules': {
"comma-dangle": ["error", "never"], //是否允许对象中出现结尾逗号
"no-cond-assign": 2, //条件语句的条件中不允许出现赋值运算符
"no-console": 2, //不允许出现console语句
"no-constant-condition": 2, //条件语句的条件中不允许出现恒定不变的量
"no-control-regex": 2, //正则表达式中不允许出现控制字符
"no-debugger": 2, //不允许出现debugger语句
"no-dupe-args": 2, //函数定义的时候不允许出现重复的参数
"no-dupe-keys": 2, //对象中不允许出现重复的键
"no-duplicate-ca": 2, //switch语句中不允许出现重复的ca标签
"no-empty": 2, //不允许出现空的代码块
"no-empty-character-class": 2, //正则表达式中不允许出现空的字符组
"no-ex-assign": 2, //在try catch语句中不允许重新分配异常变量
"no-extra-boolean-cast": 2, //不允许出现不必要的布尔值转换
"no-extra-parens": 0, //不允许出现不必要的圆括号
换屏幕"no-extra-mi": 2, //不允许出现不必要的分号
"no-func-assign": 2, //不允许重新分配函数声明
"no-inner-declarations": ["error", "functions"], //不允许在嵌套代码块⾥声明函数
"no-invalid-regexp": 2, //不允许在RegExp构造函数⾥出现⽆效的正则表达式
"no-irregular-whitespace": 2, //不允许出现不规则的空格
"no-negated-in-lhs": 2, //不允许在in表达式语句中对最左边的运算数使⽤取反操作
"no-obj-calls": 2, //不允许把全局对象属性当做函数来调⽤
"no-regex-spaces": 2, //正则表达式中不允许出现多个连续空格
"quote-props": 2, //对象中的属性名是否需要⽤引号引起来
"no-spar-arrays": 2, //数组中不允许出现空位置
"no-unreachable": 2, //在return,throw,continue,break语句后不允许出现不可能到达的语句
"u-isnan": 2, //要求检查NaN的时候使⽤isNaN()
"valid-jsdoc": ["error", {
"requireReturn": fal,
"requireParamDescription": fal,
"requireReturnDescription": true
汉服古装}], //强制JSDoc注释
"valid-typeof": ["error", {
"requireStringLiterals": true
}], //在使⽤typeof表达式⽐较的时候强制使⽤有效的字符串
"block-scoped-var": 2, //将变量声明放在合适的代码块⾥
"complexity": 0, //限制条件语句的复杂度
"consistent-return": 2, //⽆论有没有返回值都强制要求return语句返回⼀个值
"curly": ["error", "all"], //强制使⽤花括号的风格
"default-ca": 0, //在switch语句中需要有default语句
"dot-notation": ["error", {"allowKeywords": fal, "allowPattern": ""}], //获取对象属性的时候使⽤点号 "eqeqeq": ["error", "smart"], //⽐较的时候使⽤严格等于
"no-alert": 1, //不允许使⽤alert,confirm,prompt语句
"no-caller": 2, //不允许使⽤arguments.callee和arguments.caller属性
"guard-for-in": 0, //监视for in循环,防⽌出现不可预料的情况
"no-div-regex": 2, //不能使⽤看起来像除法的正则表达式
"no-el-return": 0, //如果if语句有return,el⾥的return不⽤放在el⾥
"no-labels": ["error", {
"allowLoop": fal,踌躇的反义词
"allowSwitch": fal
}], //不允许标签语句
"no-eq-null": 2, //不允许对null⽤==或者!=
"no-eval": 2, //不允许使⽤eval()
"no-extend-native": 2, //不允许扩展原⽣对象
"no-extra-bind": 2, //不允许不必要的函数绑定
"no-fallthrough": 2, //不允许switch按顺序全部执⾏所有ca
"no-floating-decimal": 2, //不允许浮点数缺失数字
"no-implied-eval": 2, //不允许使⽤隐式eval()
"no-iterator": 2, //不允许使⽤__iterator__属性
"no-lone-blocks": 2, //不允许不必要的嵌套代码块
"no-loop-func": 2, //不允许在循环语句中进⾏函数声明
"no-multi-spaces": 2, //不允许出现多余的空格
"no-multi-str": 2, //不允许⽤\来让字符串换⾏
"no-global-assign": 2, //不允许重新分配原⽣对象
"no-new": 2, //不允许new⼀个实例后不赋值或者不⽐较
"no-new-func": 2, //不允许使⽤new Function
"no-new-wrappers": 2, //不允许使⽤new String,Number和Boolean对象
"no-octal": 2, //不允许使⽤⼋进制字⾯值
"no-octal-escape": 2, //不允许使⽤⼋进制转义序列
"no-param-reassign": 0, //不允许重新分配函数参数"no-proto": 2, //不允许使⽤__proto__属性
"no-redeclare": 2, //不允许变量重复声明
"no-return-assign": 2, //不允许在return语句中使⽤分配语句
"no-script-url": 2, //不允许使⽤javascript:void(0)
"no-lf-compare": 2, //不允许⾃⼰和⾃⼰⽐较
"no-quences": 2, //不允许使⽤逗号表达式
"no-throw-literal": 2, //不允许抛出字⾯量错误 throw "error"
"no-unud-expressions": 2, //不允许⽆⽤的表达式
"no-void": 2, //不允许void操作符
"no-warning-comments": [1, {"terms": ["todo", "fixme", "any other term"]}], //不允许警告备注栾川旅游
"no-with": 2, //不允许使⽤with语句
"radix": 1, //使⽤parInt时强制使⽤基数来指定是⼗进制还是其他进制
"vars-on-top": 0, //var必须放在作⽤域顶部
堂安侗寨"wrap-iife": [2, "any"], //⽴即执⾏表达式的括号风格
车刀材料"yoda": [2, "never", {"exceptRange": true}], //不允许在if条件中使⽤yoda条件
"strict": [2, "function"], //使⽤严格模式
"no-catch-shadow": 2, //不允许try catch语句接受的err变量与外部变量重名"no-delete-var": 2, //不允许使⽤delete操作符 "no-label-var": 2, //不允许标签和变量同名
"no-shadow": 2, //外部作⽤域中的变量不能与它所包含的作⽤域中的变量或参数同名
"no-shadow-restricted-names": 2, //js关键字和保留字不能作为函数名或者变量名
"no-undef": 2, //不允许未声明的变量
"no-undef-init": 2, //不允许初始化变量时给变量赋值undefined
"no-undefined": 2, //不允许把undefined当做标识符使⽤
"no-unud-vars": [2, {"vars": "all", "args": "after-ud"}], //不允许有声明后未使⽤的变量或者参数
"no-u-before-define": [2, "nofunc"], //不允许在未定义之前就使⽤变量"indent": 2, //强制⼀致的缩进风格
"brace-style": [2, "1tbs", { "allowSingleLine": fal}], //⼤括号风格
"camelca": [2, {"properties": "never"}], //强制驼峰命名规则
"comma-style": [2, "last"], //逗号风格
"consistent-this": [0, "lf"], //当获取当前环境的this是⽤⼀样的风格
"eol-last": 2, //⽂件以换⾏符结束
"func-names": 0, //函数表达式必须有名字
"func-style": 0, //函数风格,规定只能使⽤函数声明或者函数表达式
"key-spacing": [2, {"beforeColon": fal, "afterColon": true}], //对象字⾯量中冒号的前后空格
"max-nested-callbacks": 0, //回调嵌套深度
"new-cap": [2, {"newIsCap": true, "capIsNew": fal}], //构造函数名字⾸字母要⼤写
"new-parens": 2, //new时构造函数必须有⼩括号
"newline-after-var": 0, //变量声明后必须空⼀⾏
小学生顺口溜"no-array-constructor": 2, //不允许使⽤数组构造器
"no-inline-comments": 0, //不允许⾏内注释
"no-lonely-if": 0, //不允许el语句内只有if语句
"no-mixed-spaces-and-tabs": [2, "smart-tabs"], //不允许混⽤tab和空格
"no-multiple-empty-lines": [2, {"max": 2}], //空⾏最多不能超过两⾏
"no-nested-ternary": 2, //不允许使⽤嵌套的三⽬运算符
"no-new-object": 2, //禁⽌使⽤new Object()
"fun-call-spacing": 2, //函数调⽤时,函数名与()之间不能有空格
"no-ternary": 0, //不允许使⽤三⽬运算符
"no-trailing-spaces": 2, //⼀⾏最后不允许有空格
"no-underscore-dangle": 2, //不允许标识符以下划线开头
讲述英文"no-extra-parens": 0, //不允许出现多余的括号
"one-var": 0, //强制变量声明放在⼀起
"operator-assignment": 0, //赋值运算符的风格
"padded-blocks": [2, "never"], //块内⾏⾸⾏尾是否空⾏
"quote-props": 0, //对象字⾯量中属性名加引号
"quotes": [1, "single", "avoid-escape"], //引号风格
"mi": [2, "always"], //强制语句分号结尾
"mi-spacing": [2, {"before": fal, "after": true}], //分后前后空格
"sort-vars": 0, //变量声明时排序
"space-before-blocks": [2, "always"], //块前的空格
"space-before-function-paren": [2, {"anonymous": "always", "named": "never"}], //函数定义时括号前的空格 "space-infix-ops": [2, {"int32Hint": true}], //操作符周围的空格
"keyword-spacing": 2, //关键字前后的空格
"space-unary-ops": [2, { "words": true, "nonwords": fal}], //⼀元运算符前后不要加空格
"wrap-regex": 2, //正则表达式字⾯量⽤括号括起来
"no-var": 0, //使⽤let和const代替var
"generator-star-spacing": [2, "both"], //⽣成器函数前后空格
"max-depth": 0, //嵌套块深度
"max-len": 0, //⼀⾏最⼤长度,单位为字符
"max-params": 0, //函数最多能有多少个参数
"max-statements": 0, //函数内最多有⼏个声明
"no-bitwi": 0, //不允许使⽤位运算符
"no-plusplus": 0 //不允许使⽤++ --运算符
}