ESLint入门
一、ESLint是什么?
ESLint是一个用于识别和报告ECMAScript/JavaScript中代码格式的工具,目的是使代码风格更加统一和避免错误。ESLint的理念是可扩展、每条规则独立、不内置编码风格。
二、为什么要使用ESLint?
在多人协作时,统一的代码风格更具可读性、可维护性。即使是单人开发,也可以使用ESLint来规范自己的书写规范。毕竟,规范化代码也是提升效率的一个方面。
而且,ESLint可以集成到主流的编辑器和构建工具中,以便我们在编写的代码的同时进行lint。
以 WebStorm 为例,只要全局安装 ESLint 或者在项目中依赖中添加 ESLint ,然后在设置里开启 ESLint 即可。其他编辑可以从官方文档(https://eslint.org/docs/user-guide/integrations)中获得具体信息。
三、如何使用ESLint?
1 安装和使用
有两种方式去安装ESLint:全局和本地。
1.1 本地安装和使用
如果要将ESLint作为项目构建系统的一部分,那么选择在本地进行安装。 您可以使用npm:
npm install eslint --save-dev
然后您需要建立一个配置文件:
./node_modules/.bin/eslint --init
接着,你可以在您的项目根目录运行ESLint:
./node_modules/.bin/eslint yourfile.js
您使用的任何插件或可共享配置也必须在本地安装,以此与本地安装的ESLint配合使用。
1.2 全局安装和使用
如果要使ESLint可以运用你的所有项目,那么选择在全局安装ESLint。 你可以使用npm:
npm install -g eslint
然后您需要建立一个配置文件:
eslint --init
接着,你可以在您的项目根目录运行ESLint:
eslint yourfile.js
您使用的任何插件或可共享配置也必须在全局安装,以此与全局安装的ESLint配合使用。
2 配置
在运行eslint --init之后,会在您的目录建立一个.eslintrc文件。在其中您将看到一些如下的配置规则:
{
"rules": {
"semi": ["error", "always"],
"quotes": ["error", "double"]
}
}
“semi”和“quotes”是ESLint中规则的名称。 第一个值是规则的错误级别,可以是以下值之一:
- "off" 或 0 - 关闭规则
- "warn" 或 1 - 将规则作为警告
- "error" 或 2 - 将规则作为错误
这三个错误级别允许您细微地控制ESLint如何应用规则。
您的.eslintrc配置文件将同样包含该行:
"extends": "eslint:recommended"
由于这一行,规则页面上标记为“”的所有规则都将被打开。
ESLint被设计为可完全配置的,配置ESLint有两种主要的方法:
- 注释配置 - 使用JavaScript注释将配置信息直接嵌入文件。
- 配置文件 - 使用JavaScript,JSON或YAML文件来指定整个目录及其所有子目录的配置信息。
这可以是格式为.eslintrc.*文件或package.json中的eslintConfig域,这两个ESLint都将自动查找和读取,也可以在命令行中指定配置文件。
有几个可配置的信息:
- Environment - 您的脚本被设计在所运行的环境。每个环境都带有一组预定义的全局变量。
- Globals - 您的脚本在执行期间访问的其他全局变量。
- Rules - 启用的规则和错误的级别。
更多配置选项和细节,看官方配置文档(http://eslint.org/docs/user-guide/configuring)。
四、常用的ESLint共享配置
因为一个配置文件可以被基础配置中的以启用的规则继承。一些公司或组织会开源出来他们使用的配置,它们以共享配置(Shareable Cinfig)的形式存在。
备注:共享配置是一个npm包,它输出一个配置对象。要确保这个包安装在ESLint能请求到的目录下。将extends的属性值指定为该对象名称即可实现继承。
1 Standard(https://github.com/standard/eslint-config-standard)
2 Airbnb(https://github.com/airbnb/javascript)
五、webpack 整合 ESLint
webpack 中通过添加 loader 的方式来使用 eslint,该 loader 名为 eslint-loader。在 webpack 中的配置如下。
/* 这是webpack配置文件的内容,省略无关部分 */
{
module: {
preLoaders: [{
test: /\.js$/, // 只针对js文件
loader: 'eslint', // 指定启用eslint-loader
include: dirVars.srcRootDir, // 指定审查范围仅为自己团队写的业务代码
exclude: [/bootstrap/], // 剔除掉不需要利用eslint审查的文件
}],
},
eslint: {
configFile: path.resolve(dirVars.staticRootDir, './.eslintrc'), // 指定eslint的配置文件在哪里
failOnWarning: true, // eslint报warning了就终止webpack编译
failOnError: true, // eslint报error了就终止webpack编译
cache: true, // 开启eslint的cache,cache存在node_modules/.cache目录里
}
}
当然也可以把 eslint-loader 放在 loaders 中,但是放置到 preLoaders 中可以先于 loader 进行处理,若 ESLint 检查到了问题就会在此停掉。如果你使用了 babel 等类似的 loader,那么通过 webpack 编译前后的代码相差就很大了,这往往导致无法 ESLint 的检查。
eslint-loader 可以采用一个配置项 eslint 来进行配置,默认会使用项目根目录下的配置文件 .eslintrc 来读取配置信息。
ESLint入门的更多相关文章
- eslint 入门项目搭建过程
github 地址 : https://github.com/gebin/eslint-demo 运行该项目 npm install npm start 访问 http://localhost:900 ...
- ESLint系列:ESLint入门安装及简单配置
1.eslint需要依赖node.js环境,在配置之前需要安装好node.js; 2.npm install eslint --save-dev 或 npm install eslint --save ...
- eslint 入门学习
想学eslint已经很久了,可是每次进到官网看一下就觉得头大,无法下手,但是最近到了年底,进行年度总结,作为一个有志向的程序媛,还是要追求编码规范的,因此今天再次拿起来了eslint,记录一下我的学习 ...
- 工作中遇到的vscode配合eslint完成保存为eslint格式
vscode个人设置 // vscode的个人设置配置 { "workbench.iconTheme": "vscode-icons", "workb ...
- ESLint 使用简介
C 语言诞生之初,程序员编写的代码风格各异,在移植时会出现一些因为不严谨的代码段导致无法被编译器执行的问题.于是在 1979 年,一款叫 lint[1] 的程序被开发出来,能够通过扫描源代码检测潜在的 ...
- ESLint 使用入门 - 来自推酷
在团队协作中,为避免低级 Bug.产出风格统一的代码,会预先制定编码规范.使用 Lint 工具和代码风格检测工具,则可以辅助编码规范执行,有效控制代码质量. 在以前的项目中,我们选择 JSHint 和 ...
- ESLint 使用入门
在团队协作中,为避免低级 Bug.产出风格统一的代码,会预先制定编码规范.使用 Lint 工具和代码风格检测工具,则可以辅助编码规范执行,有效控制代码质量. 在以前的项目中,我们选择 JSHint 和 ...
- Eslint 从入门到放弃
https://blog.csdn.net/walid1992/article/details/54633760
- ESLint的使用笔记
原文地址:https://csspod.com/getting-started-with-eslint/?utm_source=tuicool&utm_medium=referral 在团队协 ...
随机推荐
- MaintainableCSS 《可维护性 CSS》 --- 复用篇
复用 通常,Harry Roberts 所说的 DRY (Don't repeat yourself) 经常被曲解成永远不要重复做通一件事. 但实际上这是不现实的,而且常常导致过分抽象,用太多的精力去 ...
- CentOS7.2上用KVM安装虚拟机window10踩过的坑
最近两个星期一直在琢磨kvm安装window10操作系统,并且通过桥接模式与外界通信,经历了九九八十一难,终于搞定.下面就记录以下我们在探索的过程中踩过的坑. 安装KVM 1. 系统要求:需要一台可以 ...
- CCS学习(三)
边框样式 边框线 dorder-style (top 上: bottom 下: left 左: right 右) 样式:none | hidden | dotted | dashed | sol ...
- ES6中的Set、Map数据结构
Map.Set都是ES6新的数据结构,他们都是新的内置构造函数.也就是说typeof的结果,多了两个. 他们是什么: Set是不能重复的数组. Map是可以任何东西当做键的对象: ES6 提供 ...
- Maven基础
Maven基础 maven核心内容:依赖管理. Maven是Apache组织的开源项目,是项目构建工具.用来管理jar包之间的相互依赖关系 Maven是一个项目构建和管理的工具,提供了帮助管理,构建, ...
- python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。
本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding: ...
- SSH三大框架的各自工作流程
一.Struts2的工作流程:1.用户在客户端发起请求,客户端会初始化一个servlet容器请求:2.servlet容器把请求会传递给context容器,context容器找到目标web工程.3.进行 ...
- (转)linux常用查看硬件设备信息命令
场景:在一篇博客中看到这些总结性命令,感觉很实用就转载,以后用到进行相关的整理 系统 # uname -a # 查看内核/操作系统/CPU信息 # lsb_release -a # 查看操作系统版本 ...
- 接口工具-POSTMAN
前端的一项总要工作就是测试接口,当然这也可能是你们后台人员做的.不管怎样,都需要测试接口,那么就来介绍一款谷歌浏览器接口测试插件,postman.首先你要去谷歌的应用商店,搜索这个插件,(需要FQ), ...
- Hbase 基础 - shell 与 客户端
版权说明: 本文章版权归本人及博客园共同所有,转载请标明原文出处(http://www.cnblogs.com/mikevictor07/),以下内容为个人理解,仅供参考. 一.简介 Hbase是在 ...