一、ESLint
协同开发过程中,经常感受到来自代码检视的恶意。代码习惯不一致,看半天;居然提交低级错误,我的天(╯‵□′)╯︵┻━┻!...研究了一番,决定使用ESLint来做代码规范检查。
二、配置方式
- JavaScript注释:通过JavaScript注释把配置信息嵌入代码中。
- package.json:在package.json文件中的eslintConfig字段中指定配置。
- 配置文件:通过.eslintrc.(js/json/yaml/yml)的独立文件来为整个目录或者子目录指定配置信息,ESlint会查找并且自动读取配置文件。
三、配置过程(配置文件)
安装相关npm包
yarn add eslint babel-eslint eslint-plugin-vue eslint-friendly-formatter --dev
增加文件
- .eslintignore 用来配置不需要检查的文件(类似git的.gitignore)。
- .eslintrc.js 用来配置ESlint验证规则的配置文件。
修改webpack配置文件
module.exports = { module: { rules: [ test: /\.(js|vue)$/, loader: "eslint-loader", enforce: "pre", //指定检查的目录 include: [resolve(__dirname, 'src')], //eslint检查报告的格式规范 options: { formatter: require("eslint-friendly-formatter") } ] } }
四、配置文件详解
以.eslintrc.js为例
module.exports = { //一旦配置了root,ESlint停止在父级目录中查找配置文件 root: true, //解析器 parser: "babel-eslint", //想要支持的JS语言选项 parserOptions: { //启用ES6语法支持(如果支持es6的全局变量{env: {es6: true}},则默认启用ES6语法支持) //此处也可以使用年份命名的版本号:2015 ecmaVersion: 6, //默认为script sourceType: "module", //支持其他的语言特性 ecmaFeatures: { //... } }, //代码运行的环境,每个环境都会有一套预定义的全局对象,不同环境可以组合使用 env: { es6: true, browser: true, jquery: true }, //访问当前源文件中未定义的变量时,no-undef会报警告。 //如果这些全局变量是合规的,可以在globals中配置,避免这些全局变量发出警告 globals: { //配置给全局变量的布尔值,是用来控制该全局变量是否允许被重写 test_param: true }, //支持第三方插件的规则,插件以eslint-plugin-作为前缀,配置时该前缀可省略 //检查vue文件需要eslint-plugin-vue插件 plugins: ["vue"], //集成推荐的规则 extends: ["eslint:recommended", "plugin:vue/essential"], //启用额外的规则或者覆盖默认的规则 //规则级别分别:为"off"(0)关闭、"warn"(1)警告、"error"(2)错误--error触发时,程序退出 rules: { //关闭“禁用console”规则 "no-console": "off", //缩进不规范警告,要求缩进为2个空格,默认值为4个空格 "indent": ["warn", 2, { //设置为1时强制switch语句中case的缩进为2个空格 "SwitchCase": 1, //分别配置var、let和const的缩进 "VariableDeclarator": { "var": 2, "let": 2, "const": 3 } }], //定义字符串不规范错误,要求字符串使用双引号 quotes: ["error", "double"], //.... //更多规则可查看http://eslint.cn/docs/rules/ } }
使用JavaScript注释启用或禁止指定规则
/* eslint-disable */ alert('message'); /* eslint-enable no-alert, no-console*/ ...
层叠配置
ESlint支持层叠配置,检测文件的规则是其目录层级结构中所有.eslintrc文件的组合,当规则冲突的时候,离检测文件最近的规则优先。
默认情况下,ESlint会沿着父级目录网上寻找配置文件,直到根目录。如果配置文件中有root: true,则ESlint会停止在父级目录中查找。
五、配置过程中出现的问题
出现错误:Use the latest vue-eslint-parser。
解决方法: 把parser: "babel-eslint"移动到parserOptions中。
{ //parser: "babel-eslint", parserOptions: { parser: "babel-eslint", //... } }
问题原因: eslint-plugin-vue中的很多规则都需要vue-eslint-parser检查<template>, vue-eslint-parser和babel-parser二者有冲突。
参考链接
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]