资讯专栏INFORMATION COLUMN

使用ESLint和sublimeLinter实时检测前端项目代码规范性[增Atom配置]

lei___ / 2577人阅读

摘要:是一种用于识别代码格式错误的工具,目的是使代码更加规范和一致并避免错误。但是它本身并没有代码检查的功能,需要借助这样的特定语言检查支持。安装以后修改配置文件。

问题描述

使用vue-cli来构建Vuejs应用的项目中默认安装了eslint-loader模块,eslint-loader模块是目前相对比较流行的代码检测工具,可以检测书写的代码是否符合统一规范,可以在一些比较大型的项目开发中统一开发人员的代码风格,这也就是为什么代码缩进有可能导致页面报错的原因。

不过若稍不小心的缩进错误就导致页面报错[如下图],那开发调试效率可想而知了,有没有办法可以直接在编码的时候就发现这些小错误。答案是肯定的,以sublimeText编辑器为例,结合sublimeLinter插件让不规范的代码先知选觉。

ESLint

ESLint是一种用于识别ECMAScript/JavaScript代码格式错误的工具,目的是使代码更加规范和一致并避免错误。

SublimeLinter

SublimeLinter 是一个代码检查框架插件,功能非常强大,支持各种语言的检查。但是它本身并没有代码检查的功能,需要借助 ESLint 这样的特定语言检查支持。我们只需要使用对应的 SublimeLinter-contrib-eslint 插件即可

步骤

全局安装ESLint

npm install eslint -g

全局安装babel-eslint。ESLint不支持Babel支持的一些语法节点。

npm install babel-eslint –g

配置sublime

通过package control安装SublimeLinter,在 Sublime textCtrl + Shift + p > Package Control:Install Package 里面搜索关键词 linter,选择”SublimeLinter”,注意别选成了 SummitLinter,另外安装完成以后退出重启r"j。若搜不到直接下载包到Sublime Text 3安装目录下:

cd "/path/to/Sublime Text 3/Packages"
git clone https://github.com/SublimeLinter/SublimeLinter3.git SublimeLinter

同理,安装SublimeLinter-contrib-eslint

安装以后修改SublimeLinter配置文件。Preferences->PackageSettings->SublimeLinter->Settings-User:

"user": {
      "linters": {
            "eslint": { "@disable":false, "args": [], "excludes": [] }
      },
      ……
      "show_errors_on_save": true,  //为true时,保存文件时,会弹出该文件所有不规范的列表及具体规则名
      ……
      "mark_style": "outline",
      "no_column_highlights_line": false,
      "passive_warnings": false,
      "paths": {
          "linux": [],
          "osx": [],
          "windows": ["C:/Users//AppData/Roaming/npm/eslint.cmd"] //全局安装ESLint生成的eslint.cmd的目录
      },
      "python_paths": {
          "linux": [],
          "osx": [],
          "windows": []
      }
}

4.配置ESLint验证规则(可以到ESLint官网自己配置rule)

到项目根目录下面使用 eslint 命令交互式的生成配置文件

生成的配置文件如下

查看效果

在编辑器中已经可以看到代码格式不规范的地方了!

ESLint规则详解
       "quotes": [0, "single"],                  //建议使用单引号
       "no-inner-declarations": [0, "both"],     //不建议在{}代码块内部声明变量或函数
       "no-extra-boolean-cast":1,               //多余的感叹号转布尔型
       "no-extra-semi": 1,                       //多余的分号
       "no-extra-parens": 1,                     //多余的括号
       "no-empty": 1,                            //空代码块
       "no-use-before-define": [1, "nofunc"],    //使用前未定义
       "complexity": [1, 10],                    //圈复杂度大于10 警告

       //常见错误
       "comma-dangle": [2, "never"],             //定义数组或对象最后多余的逗号
       "no-debugger": 2,                         //debugger 调试代码未删除
        "no-constant-condition":2,               //常量作为条件
       "no-dupe-args": 2,                        //参数重复
       "no-dupe-keys": 2,                        //对象属性重复
       "no-duplicate-case": 2,                   //case重复
       "no-empty-character-class": 2,            //正则无法匹配任何值
       "no-invalid-regexp": 2,                   //无效的正则
       "no-func-assign": 2,                      //函数被赋值
       "valid-typeof": 2,                        //无效的类型判断
       "no-unreachable": 2,                      //不可能执行到的代码
       "no-unexpected-multiline": 2,             //行尾缺少分号可能导致一些意外情况
       "no-sparse-arrays": 2,                    //数组中多出逗号
       "no-shadow-restricted-names": 2,          //关键词与命名冲突
        "no-undef": 2,                            //变量未定义
       "no-unused-vars": 2,                      //变量定义后未使用
       "no-cond-assign": 2,                      //条件语句中禁止赋值操作
       "no-native-reassign": 2,                  //禁止覆盖原生对象

       //代码风格优化
       "no-else-return": 1,                      //在else代码块中return,else是多余的
       "no-multi-spaces": 1,                     //不允许多个空格
       "key-spacing": [1, {"beforeColon": false,"afterColon": true}],//object直接量建议写法 : 后一个空格前面不留空格
       "block-scoped-var": 2,                    //变量应在外部上下文中声明,不应在{}代码块中
       "consistent-return": 2,                   //函数返回值可能是不同类型
       "accessor-pairs": 2,                      //object getter/setter方法需要成对出现
       "dot-location": [2, "property"],          //换行调用对象方法  点操作符应写在行首
       "no-lone-blocks": 2,                      //多余的{}嵌套
       "no-empty-label": 2,                      //无用的标记
       "no-extend-native": 2,                    //禁止扩展原生对象
       "no-floating-decimal": 2,                 //浮点型需要写全 禁止.1 或 2.写法
       "no-loop-func": 2,                        //禁止在循环体中定义函数
       "no-new-func": 2,                         //禁止new Function(...) 写法
       "no-self-compare": 2,                     //不允与自己比较作为条件
       "no-sequences": 2,                       //禁止可能导致结果不明确的逗号操作符
       "no-throw-literal": 2,                    //禁止抛出一个直接量 应是Error对象
       "no-return-assign": [2, "always"],        //不允return时有赋值操作
       "no-redeclare": [2, {"builtinGlobals": true}],//不允许重复声明
       "no-unused-expressions": [2, {"allowShortCircuit":true, "allowTernary": true}],//不执行的表达式
       "no-useless-call": 2,                     //无意义的函数call或apply
       "no-useless-concat": 2,                   //无意义的string concat
       "no-void": 2,                             //禁用void
       "no-with": 2,                             //禁用with
       "space-infix-ops": 2,                     //操作符前后空格
       "valid-jsdoc": [2, {"requireParamDescription": true,"requireReturnDescription": true}],//jsdoc
       "no-warning-comments": [2, { "terms":["todo", "fixme", "any other term"],"location": "anywhere" }],//标记未写注释
       "curly": 1                                //if、else、while、for代码块用{}包围

延伸阅读

在Atom中配置
# 安装linter 和 linter-eslint
# 需要配置环境变量(C:UsersAppDataLocalatomin)后才能使用apm命令
# 或者在setting中安装
$ apm install linter linter-eslint
# 安装完重启Atom

此时已经能开到代码错误提示

校验.vue文件中的 JS 代码

此时只有.js文件能被校验,.vue中的

忽略main.js文件
/* eslint-disable no-new */
new Vue({
  el: "#app",
  router,
  render: h => h(App)
})

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/83998.html

相关文章

  • Sublime Text 中配置 Eslint 代码检查自动修复

    摘要:它的目标是提供一个插件化的代码检测工具。,有了全局的和当前项目根目录下的规则配置文件,我们开始装插件并测试功能吧代码检查这个功能需要的插件为和。但是它本身并没有代码检查的功能,需要借助这样的特定语言检查支持。 前言 第一次运行 Vue 项目时被浏览器中满屏的 ESLint 报错给吓到了,果断禁用了该功能! 再之后找了个时间认真的了解了一下 ESLint,终于有了一些概念。简单来说,ES...

    yunhao 评论0 收藏0
  • 一个靠谱的前端开源项目需要什么?

    摘要:一个靠谱的应该包含以下几部分言简意赅的项目介绍你的项目解决了什么核心问题,有哪些令人心动的特性。除了在中提到遵循的开源协议外,一个靠谱的开源项目还会将该开源协议的内容文档放在自己的项目下方。 0. 前言 写前端代码一段时间之后,你可能会萌生做一个开源项目的想法,一方面将自己的好点子分享出去让更多的人受益,另一方面也可以在社区贡献的环境下学到更多的东西从而快速成长。但是开源项目也有开源项...

    hiyayiji 评论0 收藏0
  • 一个靠谱的前端开源项目需要什么?

    摘要:一个靠谱的应该包含以下几部分言简意赅的项目介绍你的项目解决了什么核心问题,有哪些令人心动的特性。除了在中提到遵循的开源协议外,一个靠谱的开源项目还会将该开源协议的内容文档放在自己的项目下方。 0. 前言 写前端代码一段时间之后,你可能会萌生做一个开源项目的想法,一方面将自己的好点子分享出去让更多的人受益,另一方面也可以在社区贡献的环境下学到更多的东西从而快速成长。但是开源项目也有开源项...

    DesGemini 评论0 收藏0
  • Vue项目使用eslint的笔录,编辑器采用sublime3

    摘要:一前言本文主要针对编辑器是的项目进行代码规范。因此对进行语法检查的工具应运而生,目前使用最为广泛。这篇将讲解如何将集成到我们的项目中。七总结在项目上使用实际上还算相对简单的,但是对于什么都是半生半熟的知识技能的人来说还是花了点时间。 一、前言 本文主要针对编辑器是sublime的vue项目进行eslint代码规范。 Javascript 是一门弱类型语言,所以语法检查变得尤为重要。虽然...

    刘明 评论0 收藏0
  • Sublime Text 3 搭建 React.js 开发环境

    摘要:有很强的自定义功能,插件库很庞大,针对新语言插件更新很快,配合使用可以快速搭建适配语言的开发环境。该命令依赖于包。源目录路径输出路径把所有东西放入缓存中,每次只编译修改过的文件发生错误时不会中断的流程,同时触发消息提示在命令行中输入运行。 Sublime有很强的自定义功能,插件库很庞大,针对新语言插件更新很快,配合使用可以快速搭建适配语言的开发环境。 1. babel-sublime ...

    Big_fat_cat 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<