介绍

ESLint 由 JavaScript 红宝书 作者 Nicholas C. Zakas 编写, 2013 年发布第一个版本。 NCZ 的初衷不是重复造一个轮子,而是在实际需求得不到 JSHint 团队响应 的情况下做出的选择:以可扩展、每条规则独立、不内置编码风格为理念编写一个 lint 工具。
官方地址:http://eslint.org/
EsLint帮助我们检查Javascript编程时的语法错误。比如:在Javascript应用中,你很难找到你漏泄的变量或者方法。EsLint能够帮助我们分析JS代码,找到bug并确保一定程度的JS语法书写的正确性。
EsLint是建立在Esprima(ECMAScript解析架构)的基础上的。Esprima支持ES5.1,本身也是用ECMAScript编写的,用于多用途分析。EsLint不但提供一些默认的规则(可扩展),也提供用户自定义规则来约束我们写的Javascript代码。
EsLint提供以下支持:
EsLint提供以下几种校验:
使用
一、安装
Npm install gulp-eslint –save-dev
在你的项目目录下,运行:eslint –init将会产生一个.eslintrc的文件,文件内容包含一些校验规则
{
"rules": {
"semi": ["error", "always"],
"quotes": ["error", "double"]
}
}
其中”semi”和”quotes”是规则名称。EsLint还提供了error的级别,对应数字,数字越高错误的提示越高,如0代码错误不提示、1代表警告提醒但不影响现有编译、2error会抛出错误。
"extends": "eslint:recommended"
Extends是EsLint默认推荐的验证,你可以使用配置选择哪些校验是你所需要的,可以登录npmjs.com查看
二、自定义配置EsLint
之前提到你可以关掉所有EsLint默认的验证,自行添加所确切需要的验证规则。为此EsLint提供了2个种方式进行设置:
开始介绍EsLint的用法
parserOptions
EsLint通过parserOptions,允许指定校验的ecma的版本,及ecma的一些特性
{
"parserOptions": {
"ecmaVersion": 6, //指定ECMAScript支持的版本,6为ES6
"sourceType": "module", //指定来源的类型,有两种”script”或”module”
"ecmaFeatures": {
"jsx": true//启动JSX
},
}
}
Parser
EsLint默认使用esprima做脚本解析,当然你也切换他,比如切换成babel-eslint解析
{
"parser": "esprima" //默认,可以设置成babel-eslint,支持jsx
}
Environments
Environment可以预设好的其他环境的全局变量,如brower、node环境变量、es6环境变量、mocha环境变量等
{
"env": {
"browser": true,
"node": true
}
}
如果你想使用插件中的环境变量,你可以使用plugins指定,如下
{
"plugins": ["example"],
"env": {
"example/custom": true
}
}
Globals
指定你所要使用的全局变量,true代表允许重写、false代表不允许重写
{
"globals": {
"var1": true,
"var2": false
}
}
Plugins
EsLint允许使用第三方插件
{
"plugins": [
"react"
]
}
Rules
自定义规则,一般格式:”规则名称”:error级别系数。系数0为不提示(off)、1为警告(warn)、2为错误抛出(error),可指定范围,如[1,4]
可以包括Strict模式、也可以是code的方式提醒,如符号等。还可以是第三方的校验,如react。
默认校验的地址http://eslint.org/docs/rules/
{
"plugins": [
"react"
],
"rules": {
//Javascript code 默认校验
"eqeqeq": "off", //off = 0
"curly": "error", //error = 2
"quotes": ["warn", "double"], //warn = 1
//使用第三方插件的校验规则
"react/jsx-quotes": 0
}
}
https://www.npmjs.com/package/eslint-plugin-react , 此链接是react的eslint使用
三、Gulp中使用
var eslint = require('gulp-eslint');
gulp.task('validate-eslint',function(){
return gulp.src(['app/**/*.js']) //指定的校验路径
.pipe(eslint({configFle:"./.eslintrc"})) //使用你的eslint校验文件
.pipe(eslint.format())
});
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
# eslint
# 配置
# gulp
# 自定义
# 你可以
# 第三方
# 红宝书
# 重写
# 所要
# 越高
# 抛出
# 全局变量
# 还可以
# 第一个
# 将会
# 你也
# 基础上
# 你想
# 到你
# 几种
# 你所
# 这篇文章
# 有两种
相关文章:
如何用PHP工具快速搭建高效网站?
宝塔Windows建站如何避免显示默认IIS页面?
贸易公司网站制作流程,出口贸易网站设计怎么做?
如何在橙子建站中快速调整背景颜色?
建站之星好吗?新手能否轻松上手建站?
建站之星如何开启自定义404页面避免用户流失?
网站制作壁纸教程视频,电脑壁纸网站?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
行程制作网站有哪些,第三方机票电子行程单怎么开?
建站之星代理如何优化在线客服效率?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
建站三合一如何选?哪家性价比更高?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
如何快速配置高效服务器建站软件?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
建站之星安装提示数据库无法连接如何解决?
长沙企业网站制作哪家好,长沙水业集团官方网站?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
建站之星如何修改网站生成路径?
如何用美橙互联一键搭建多站合一网站?
三星网站视频制作教程下载,三星w23网页如何全屏?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
如何使用Golang table-driven基准测试_多组数据测量函数效率
如何在云主机快速搭建网站站点?
如何彻底卸载建站之星软件?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
建站之星北京办公室:智能建站系统与小程序生成方案解析
安云自助建站系统如何快速提升SEO排名?
如何在云服务器上快速搭建个人网站?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
宿州网站制作公司兴策,安徽省低保查询网站?
建站主机服务器选型指南与性能优化方案解析
微信推文制作网站有哪些,怎么做微信推文,急?
如何在阿里云虚拟主机上快速搭建个人网站?
如何获取上海专业网站定制建站电话?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
郑州企业网站制作公司,郑州招聘网站有哪些?
购物网站制作公司有哪些,哪个购物网站比较好?
如何快速搭建高效服务器建站系统?
如何在阿里云虚拟服务器快速搭建网站?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
大连 网站制作,大连天途有线官网?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
*请认真填写需求信息,我们会在24小时内与您取得联系。