开发eslint插件目的:根据项目需要,自定义满足项目特殊需要的校验规则

参考eslint官方文档展开阐述

下面开始通过一个示例demo来介绍插件整个开发流程

代码中出现的方法及变量的详细解释与相关文档,会在文末给大家列举出来,大家可以先把代码拷贝到自己的demo中然后结合本文第3部分的变量|方法解释去理解代码

开发一个校验注释中是否包含指定关键词的插件(eslint-plugin-comments-key)

1. 环境准备

目录结构

.
├── README.md 插件介绍文档
├── index.js 对外暴露插件
├── lib
│   └── rules 自定义规则
│   └── comments-key.js
├── package.json
└── tests 测试自定义规则
└── lib
└── rules
└── comments-key.js

安装依赖

  • eslint
  • mocha
npm i eslint mocha -D

2. 开始编码

编写自定义规则

不包含自定义参数校验规则

/lib/rules/comments-key.js

module.exports = {
meta: {
type: "suggestion",
docs: {
description: "Not allowed comment words", // 规则的简述
category: "Stylistic Issues", // 规则分类
recommended: true // 配置文件中的 "extends": "eslint:recommended"属性是否启用该规则
}
},
create: function (context) {
// context对象包含与规则上下文相关的信息
// 返回一个SourceCode对象,你可以使用该对象处理传递给 ESLint 的源代码
const sourceCode = context.getSourceCode() // 定义不被允许出现在注释中的内容
const notAllowWords = ['fixme', 'xxx']
return {
Program(node) {
// 获取所有注释的节点
const comments = sourceCode.getAllComments()
// 遍历注释节点判断是否有不符合规范的
comments.forEach(comment => {
let { loc, value, type } = comment
value = value.toLowerCase()
let warnWord = ''
// 判断注释内容是否包含不被允许的word
for (const word of notAllowWords) {
if (value.includes(word)) {
warnWord = word
}
} if (warnWord) {
context.report({
node: comment, // 可选 与问题有关的 AST 节点
message: `注释中含有不被允许的字符${warnWord}` // 有问题发出的消息
})
}
})
}
};
}
};

编写测试用例

/tests/lib/rules/comments-key.js

const { RuleTester } = require('eslint')

// 获取自定义的规则
const rule = require('../../../lib/rules/comments-key') // TESTS
// 加入默认配置
const ruleTester = new RuleTester({
parserOptions: { ecmaVersion: 2018 }
}) const errMsg = warnWord => `注释中含有不被允许的字符${warnWord}` ruleTester.run('comments-key', rule, {
valid: [
'// sssss',
'// fixdddd',
`/**
* 容十三内水s是说
*/`
],
invalid: [
{
code: "// fixme: DDL 2020-4-28 测试内容",
errors: [{ message: errMsg('fixme') }]
},
{
code: "// FIXME: DDL 2020-5-23 测试内容",
errors: [{ message: errMsg('fixme') }]
},
{
code: `/**
* xxx
* 内容
*/`,
errors: [{ message: errMsg('xxx') }]
}
]
})

修改package.json

加入

"scripts": {
"test": "mocha tests/lib/rules"
}

运行脚本查看测试结果

npm run test

上面的示例中限定的关键词是在代码中写死了的

通常的场景中如:

rules:{
"quotes": ["error", "double"], // 只允许双引号
"no-warning-comments": [ // 不允许注释开头出现 todo|fixme等内容
1,
{
"terms": [
"todo",
"fixme"
],
"location": "start"
}
],
}

大多数eslint规则都拥有可配置的属性

我们可以通过context.options获取配置的属性

下面示例加入可配置属性,用于自定义关键词的检测(代码中只包含修改部分,其余部分跟前面相同)

module.exports = {
meta: {
// ...code
schema: [ // 指定该选项 这样的 ESLint 可以避免无效的规则配置
// 遵循 json schema 后文会有介绍文档
{
"keyWords": {
"type": "array",
"items": {
"type": "string"
}
}
}
]
},
create: function (context) {
// ...code // 定义不被允许出现在注释中的内容 // 可以使用 context.options检索一个规则的可选项,它是个数组,包含该规则的所有配置的可选项 // console.log(context.options); // 取得设置的keywords
let [argv0] = context.options
let keyWords = argv0 ? argv0.keyWords ? argv0.keyWords.length > 0 ? argv0.keyWords : undefined : undefined : undefined // 没有设置则使用默认的
let notAllowWords = keyWords || ['fixme', 'xxx'] // 忽略大小写
notAllowWords = notAllowWords.map(v => v.toLowerCase())
// ...code
}
};

完善我们的单元测试

// ...code
ruleTester.run('comments-key', rule, {
valid: [
'// sssss',
'// fixdddd',
`/**
* 容十三内水s是说
*/`
],
invalid: [
{
code: "// fixme: DDL 2020-4-28 测试内容",
errors: [{ message: errMsg('ddl') }],
options: [{ // 通过options 配置自定义参数
keyWords: ['ddl']
}]
},
{
code: '// FIXME: DDL 2020-5-23 测试内容 \n let a = "232"',
errors: [{ message: errMsg('fixme') }],
rules: { // 通过rules 配置eslint提供的一些规则
"quotes": ["error", "double"],
},
options: [{
keyWords: ['abc', 'efg', 'fixme']
}]
},
{
code: `/**
* xxx
* 内容
*/`,
errors: [{ message: errMsg('xxx') }]
},
{
code: '// abds asa',
errors: [{ message: errMsg('abd') }],
options: [{
keyWords: ['abc', 'abd']
}]
}
]
})

3.文中一些变量|方法的解释及其文档

  • meta (object) 包含规则的元数据

    • schema 指定该选项 这样的 ESLint 可以避免无效的规则配置

  • create (function) 返回一个对象,其中包含了 ESLint 在遍历 JavaScript 代码的抽象语法树 AST (ESTree 定义的 AST) 时,用来访问节点的方法
    • context 包含与规则上下文相关的信息

      • options 检索一个规则的可选项,它是个数组,包含该规则的所有配置的可选项
      • getSourceCode() 返回一个SourceCode对象,你可以使用该对象处理传递给 ESLint 的源代码
        • getAllComments() 获取所有注释节点

          • 每个注释节点的属性

            • loc 注释在文档中的位置
            • value 注释中的内容
            • type 注释的类型 BlockLine
      • report() 它用来发布警告或错误(取决于你所使用的配置)。该方法只接收一个参数,是个对象
        • message 有问题的消息提示
        • node (可选)与问题有关节点
        • loc (可选)用来指定问题位置的一个对象。如果同时指定的了 loc 和 node,那么位置将从loc获取而非node
        • data (可选) message的占位符
        • fix (可选) 一个用来解决问题的修复函数
  • RuleTester 单元测试示例介绍

tips:AST在开发插件时不必深入研究,不同地方AST的实现和结构都有所差异

4.导出

至此我们的插件算开发完成了,接下来编写对eslint暴露这个模块的代码

index.js

'use strict';
module.exports = {
rules: {
'diy': require('./lib/rules/comments-key')
},
rulesConfig: {
'diy': 1
}
};

5.发布npm

要在其它项目中使用的eslint-plugin插件的话,可以把整个插件的根目录拷贝到目标项目的node_modules中或者发布到npm中去,其它项目直接通过npm install 安装这个依赖

下面介绍发布到npm的步骤

  1. 注册npm账号(有的话直接跳过这步骤)

直接点击官网注册

  1. 设置登陆的账号

    登录之前修改registry为原来的,因为国内一般用的镜像源例如淘宝源:https://registry.npm.taobao.org
npm config set registry https://registry.npmjs.org/
npm login

按提示依次输入账号,密码,邮箱

登录完成之后,查看当前npm用户,不报错说明登录成功

npm whoami
  1. 编写README.md方便指引他人使用
  2. 修改packgae.json
{
"name": "eslint-plugin-comments-key",
"version": "1.0.0",
"description": "校验注释中是否包含指定关键词的插件",
"main": "index.js",
"directories": {
"lib": "lib",
"test": "tests"
},
"scripts": {
"test": "mocha tests/lib/rules"
},
"keywords": [],
"author": "",
"license": "ISC",
"devDependencies": {
"eslint": "^7.0.0",
"mocha": "^7.1.2"
}
}
  1. 运行npm publish发布npm包

至此发布整个流程完毕

6.项目中引入

Installation

You'll first need to install ESLint:

$ npm i eslint --save-dev

Next, install eslint-plugin-comments-key:

$ npm install eslint-plugin-comments-key --save-dev

Note: If you installed ESLint globally (using the -g flag) then you must also install eslint-plugin-comments-key globally.

Usage

Add comments-key to the plugins section of your .eslintrc configuration file or package.json. You can omit the eslint-plugin- prefix:

package.json demo

"eslintConfig": {
"plugins": [
"comments-key"
],
"rules": {
"comments-key/diy":[1,{
"wordKeys":["fixme","xxx"]
}]
}
}

tips: 如果编辑器中安装了Eslint插件,在编码的时候就会给予警告⚠️

最后

eslint-plugin-comments-key相关地址

因笔者水平有限,内容上如有阐述不明白之处,还请斧正

eslint插件开发教程的更多相关文章

  1. jQuery插件开发教程

    jQuery插件开发教程  ——让你的jQuery水平提升一个台阶 要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台 ...

  2. [js插件开发教程]实现一个比较完整的开源级选项卡插件

    在这篇文章中,我实现了一个基本的选项卡功能:请猛击后面的链接>>   [js插件开发教程]原生js仿jquery架构扩展开发选项卡插件. 还缺少两个常用的切换(自动切换与透明度渐变),当然 ...

  3. 【2021/12/31】uniapp之安卓原生插件开发教程

    uniapp之安卓原生插件开发教程 准备 hbuilderX,下载 app离线SDK,下载 Andorid Studio,安卓官方或中文社区 证书(可以自己准备,也可以使用android Studio ...

  4. PHPCMS 插件开发教程及经验谈

    虽说 PHPCMS 开源,但其它开发文档及参考资料实在少得可怜.进行二次开发时,自己还得慢慢去研究它的代码,实在让人郁闷. PHPCMS 的“Baibu/Google地图”实在有待改进,对于数据量比较 ...

  5. (转)跟我一起学JQuery插件开发教程

    在逛codeproject网站的时候,突然看到一篇文章:How to write plugin in Jquery. 如果对E文好的同学 ,可以看上面的连接.现在我把上面网站的及结合自己的想法写这篇文 ...

  6. [js插件开发教程]一步步开发一个可以定制配置的隔行变色小插件

    隔行变色功能,不用js,直接用css伪类就可以做,这个实例可以作为js插件开发很好的入门级实例.本文实现的隔行变色包括以下功能: 1,支持2种常用结构共存( div元素 和 表格类型 ) 2,一个页面 ...

  7. [js插件开发教程]原生js仿jquery架构扩展开发选项卡插件

    jquery插件一般是这么干的: $.fn.插件名称 = function(){}, 把插件的名称加在.fn上,在源码里面实际上是扩展到构造函数的原型对象上,如果你没看过jquery的源代码,或者你曾 ...

  8. 跟我一起学JQuery插件开发教程

    在逛codeproject网站的时候,突然看到一篇文章:How to write plugin in Jquery. 如果对E文好的同学 ,可以看上面的连接.现在我把上面网站的及结合自己的想法写这篇文 ...

  9. [js插件开发教程]定制一个手风琴插件(accordion)

    本文带来一个垂直方向的手风琴插件开发,可以定制的功能如下: contentClass : 'panel', //面板样式navClass : 'nav', //导航样式activeClass : 'a ...

随机推荐

  1. shell脚本之awk(一)

     运维必备技能 概述: 1.awk是一种编程语言,用于linux/unix下对文本和数据进行扫描.处理数据来源:标准输入.文件.管道.  2.linux中常用的awk编译器版本有mawk,gawk.R ...

  2. Dockerfle创建镜像

    简介 Dockerfile 由一行行命令语句组成,并且支持以 # 开头的注释行. 一般的,Dockerfile 分为四部分:基础镜像信息.维护者信息.镜像操作指令和容器启动时执行指令. # This ...

  3. 使用Hexo框架搭建博客,并部署到github上

    开发背景:年后回来公司业务不忙,闲暇时间了解一下node的使用场景,一篇文章吸引了我15个Nodejs应用场景,然后就被这个hexo框架吸引了,说时迟,那时快,赶紧动手搭建起来,网上找了好多资料一天时 ...

  4. L3.二.return

    # 函数的返回值 def get_max(a,b,c): max_num=a if b > max_num: max_num = b if c > max_num: max_num = c ...

  5. Qt之QListWidget:项目的多选与单选设置

    2019独角兽企业重金招聘Python工程师标准>>> #include "widget.h" #include <QApplication> #in ...

  6. 再砸4.35亿美元,LG疯狂扩建太阳能电池生产线

    LG在收缩高分辨率电视和其他消费电子产品业务的同时,在太阳能面板业务上却很明显一直在进行扩张.LG公司表示,他们将斥资4.35亿美元在韩国工厂增加超过6条生产线,使其太阳能电池生产量能够在2018年达 ...

  7. vue中 $refs的基本用法

    骚年,我看你骨骼惊奇,有撸代码的潜质,这里有324.57GB的前端学习资料传授于你!什么,你不信??? 先随便看几个图: 肯定没看够.再来个GIF图热个身??? 那么问题来了,如果你也想入坑前端或者学 ...

  8. Node.js中的express框架,修改内容后自动更新(免重启),express热更新

    个人网站 https://iiter.cn 程序员导航站 开业啦,欢迎各位观众姥爷赏脸参观,如有意见或建议希望能够不吝赐教! 以前node中的express框架,每次修改代码之后,都需要重新npm s ...

  9. Vxlan L2

    VXLAN(Virtual eXtensible LAN可扩展虚拟局域网)诞生了,基于IP网络之上,采用的是MAC in UDP技术 跨三层实现二层通信 总结为何需要Vxlan: 虚拟机规模受到网络规 ...

  10. WPF客户端自动升级

    实现原理:通过一个辅助程序(更新程序.exe)比较本地版本号和服务器的版本,若服务器版本新则通过更新程序.exe下载服务器上资源(我是把最新的文件压缩成zip放到服务器上)到本地进行替换. 服务器放置 ...