自定义ESLint规则和修复功能

news2024/11/28 18:49:50

这是接上一篇自定义ESLint规则开发与使用的后续扩展,之前文章中详细讲述了怎么创建一个自定义的规则,这篇文章讲述怎么实现ESLint在检测出有问题的代码时,怎么自动fix问题。
比如我们要检测项目中所有http的协议,将其替换为https协议。增加网页的安全性。

项目准备

所用的示例也是和上一篇文章中是一个项目。先进入eslint-plugin-demo的文件夹,使用脚手架回答一些交互式问题,建立ESLint规则文件.
在这里插入图片描述
在这里插入图片描述

创建link

我们在开发npm包的过程中,可以使用npm link将开发的包link到全局上,这样应用工程就可以直接使用了。具体详情请看npm link

我们在 eslint-plugin-diylint 根目录下执行 npm link。可以看到已近建立了全局的软连了
在这里插入图片描述
再cd到demo-app中直接npm link eslint-plugin-diylint 就可以在demo-app/node_modules安装eslint-plugin-diylint 这个插件了,我们可以直接在原文件(node_modules中customer-eslint-demo/eslint-plugin-demo/lib/rules/no-http-protocol.js)中打断点,直接调试会自动映射到node_modules对应的文件中,调试起来非常的方便。

规则实现

在这里插入图片描述
通过解析之后,我们选择’VariableDeclaration VariableDeclarator’作为visitor 来获取变量和变量的值。
将no-http-protocol.js中内容改为如下:

/**
 * @fileoverview 不可使用http协议
 * @author yjian
 */
"use strict";
/** @type {import('eslint').Rule.RuleModule} */
module.exports = {
  meta: {
    type: 'problem', // `problem`, `suggestion`, or `layout`
    docs: {
      description: "不可使用http协议",
      recommended: false,
      url: null, // URL to the documentation page for this rule
    },
    fixable: null, // Or `code` or `whitespace`
    schema: [], // Add a schema if the rule has options
    // 报错信息描述
    messages: {
      avoidHttpProtocol: "'{{name}}' value avoid using http protocol.",
    },
  },
  create(context) {
    return {
      // visitor functions for different types of nodes
      'VariableDeclaration VariableDeclarator': (node) => {
        if (node.init && node.init.value && node.init.value.includes('http://')) {
          context.report({
            node,
            messageId: 'avoidHttpProtocol',
            data: {
                name: node.id && node.id.name,
            },
          });
        }
      }
    };
  },
};

rules/index.js中内容改为如下:

/**
 * @fileoverview 自定义eslint规则
 * @author yjian
 */
"use strict";

// import all rules in lib/rules
module.exports = {
  rules: {
        // 项目在使用时,对应的规则名称
      'no-console-error': require('./rules/no-console-error'),
      'no-http-protocol': require('./rules/no-http-protocol'),
  },
  configs: {
      recommended: {
          rules: {
              'demo/no-console-error': 2, // 可以省略 eslint-plugin 前缀
              'demo/no-http-protocol': 2,
          },
      },
  },
}

规则使用

在demo-app/eslintrc.json中开启该规则

{
    "env": {
        "browser": true,
        "es2021": true
    },
    "plugins": [
        // 这是此前使用yo eslint:plugin 生成自定义插件的ID
        "diylint"
    ],
    "extends": "standard",
    "overrides": [
    ],
    "parserOptions": {
        "ecmaVersion": "latest"
    },
    "rules": {
        "diylint/no-console-error": 2,
        // 不能使用http协议
        "diylint/no-http-protocol": 2
    }
}

然后重新加载一下vscode,发现我们自定义的lint已近发挥作用,检测出使用http协议的地方了。

在这里插入图片描述
然后我们下一步添加一个自动修改的功能,将使用http协议的全部自动改成https的

ESLint 自动修改

meta 修改

将meta中的fixable的值改为code, 这样在命令行上加上-- fix 参数就会自动修复该问题
在这里插入图片描述

实现fix函数

我们需要再content.report传入的对象参数中,实现一个fix的函数。

context.report({
            node,
            messageId: 'avoidHttpProtocol',
            data: {
                name: node.id && node.id.name,
            },
            fix(fixer) {
              console.log(fixer.insertTextAfter);
              return fixer.replaceText()
            }
          });

我们可以看到fixer中有这些方法。
在这里插入图片描述
这些方法归为三类

  • 增:insertTextAfter、insertTextAfterRange、insertTextBefore、insertTextBeforeRange
  • 删:remove、removeRange
  • 改:replaceText、replaceTextRange

我们在这里需要将原来的http:修改为https:即可,所以使用的是replaceText方法
整个代码入下:

'VariableDeclaration VariableDeclarator': (node) => {
        if (node.init && node.init.value && node.init.value.includes('http://')) {
          // 将http:修改为 https:
          const httpsProtocal = node.init.value.replace(/http:/g, 'https:');
          context.report({
            node,
            messageId: 'avoidHttpProtocol',
            data: {
                name: node.id && node.id.name,
            },
            fix(fixer) {
             return fixer.replaceText(node.init, `'${httpsProtocal}'`)
            }
          });
        }
      }

在这里插入图片描述
在此之前我们再对应的代码处选择快速修复的话,只有上图两个选项是通过改规则的。而没有对应的按照该规则自动修改代码的选项。我们实现上面的方法之后就有了自动修复的选项了,就会按照上面fix函数的逻辑去修复对应的代码。
在这里插入图片描述

效果如下所示:
请添加图片描述
或者在使用命令行加–fix 也是一样的。效果如下:

请添加图片描述
至此我们就完成了一个完整的自定义ESLint规则的编写和自动修复。

参考资料

ESLint 中文文档
ESLint英文文档
AST在线解析
AST语法解析(查看node & token)
ESLint创建规则-中文
ESLint创建规则-英文
RuleTester-中文文档
Babel解析AST 节点

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/345016.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Power BI 存储模式介绍(导入、DirectQuery、双)

本系列的文章: 《Power BI windows下载安装流程)》《Power BI 11个必学官方示例数据案例(附下载链接)》《Power BI 数据导入(SQL Server、MySQL、网页数据)》 一、背景原因 一般情况下,我们是…

测试开发面试基础题

1.对测试开发的理解 测试开发首先离不开测试,而软件测试是指,在规定的条件下对程序进行操作,以发现程序错误,衡量软件质量,并对其是否能满足设计要求进行评估的过程。 而且,现在不仅仅是通过手工测试来发…

安装less-loader5出现webpack版本不兼容

今天遇到一个问题: 安装less-loader5之后其它包提示peerDependencies WARNING,意思是包版本不兼容。 【难题】 虽然NPM已经很自动化了,但依赖问题真的是一个难题,无法自动解决,需要人工干预调整。 【解决办法】 去查…

用户选择好用的投票小程序最有用的投票小程序微信推送里投票制作教程

“夏日非遗传承活动”网络评选投票_用户选择好用的投票小程序_最有用的投票小程序用户在使用微信投票的时候,需要功能齐全,又快捷方便的投票小程序。而“活动星投票”这款软件使用非常的方便,用户可以随时使用手机微信小程序获得线上投票服务…

医学生考研考博太卷,一篇文章轻松助力上岸——生物信息学及R语言基础知识之向量的生成(一)

考研考博太卷了,卷不过,想没想过本科发一篇文章呢? 330分考研人淘汰390分考研人这个故事,大家应该都知道吧。 本专栏带你六个月内,搞定一篇文章,本科生发文章也很容易。 在卷考研的同时,再卷一篇SCI,你就是新一任卷王。 本专栏教你不用花钱发一篇生信文章,从三个方…

带你了解软件测试是做什么的

软件测试是互联网技术中一门重要的学科,它是软件生命周期中不可或缺的一个环节,担负着把控、监督软件的质量的重任。 人才稀缺,对于求职者来说就意味着机会。但是很多想学习软件测试的人对这个学科并不了解,也不知道该如何学习&a…

Vue3的新特性

文章目录1 生命周期的变化2 使用proxy代替defineProperty2.1 Object.defineProperty()语法2.2 Proxy的语法3 Diff算法的提升3.1 以往的渲染策略3.2 Vue3的突破4 TypeScript的支持5 优化打包体积6 新的响应性 API6.1 reactive()6.2 <script setup>6.3 nextTick()6.4 react…

【半监督医学图像分割 2022 MICCAI】CLLE 论文翻译

文章目录【半监督医学图像分割 2022 MICCAI】CLLE 论文翻译摘要1. 简介2. 方法2.1 半监督框架概述2.2 监督局部对比学习2.3 下采样和块划分3. 实验4. 结论【半监督医学图像分割 2022 MICCAI】CLLE 论文翻译 论文题目&#xff1a;Semi-supervised Contrastive Learning for Labe…

Kafka 消息队列

目录主流的消息队列消息队列的应用场景缓存/肖锋解耦异步处理KafkaKafka的定义Kafka的底层基础架构Kafka分区如何保证Leader选举Kafka分区如何保证Leader和Follower数据的一致性Kafka 中消费者的消费方式Kafka 高效读写数据的原因&#xff08;高性能吞吐的原因&#xff09;&…

chatGPT爆火让我们反思——人工智能是新的加密货币吗?

核冬天技术末日到来了&#xff0c;只有人工智能幸免于难。峰值 AI 指标无处不在。它能保持加密失去的信念吗&#xff1f;作者&#xff1a;John Luttig 翻译: Chainwise核冬天技术末日到来了&#xff1a;软件、SPAC、金融科技和加密货币都进入了深度冻结状态。AI 可能是唯一穿着…

JavaWeb_RequestResponse

目录 一、概述 二、Request对象 1.Request继承体系 2.Request获取请求数据 ①获取请求行数据 ②获取请求头数据 ③获取请求体数据 ④获取请求参数 3.Request请求转发 三、Response 1.Response设置响应数据功能 ①响应行 ②响应头 ③响应体 2.请求重定向 3.路径问…

原生开发 之 微信小程序

目录 一、前期预备 1. 预备知识 ​2. 注册账号 - 申请AppID 3. 下载小程序开发工具 4. 小程序项目结构 ​5. 小程序的MVVM架构 二、创建小程序项目 1. 查看注册的appId ​2. 创建项目 ​3. 新建页面 01 - 创建text页面文件夹 ​02 - 新建text的page ​03 - 在app.json中配置 ​…

Python Paramiko stdout 多进程 阻塞 卡住 问题解决

使用paramiko进程远程操作时&#xff0c;如果缓冲区满了&#xff0c;exec_command在写入该缓冲区时会产生阻塞并一直保持阻塞状态&#xff0c;直到缓冲区被清空为止。 使用multiprocessing无疑会加重这种情况&#xff0c;其中一种解决办法是设置exec_command的get_pty参数为Tru…

商城业务:购物车

人生在世如身处荆棘之中&#xff0c;心不动&#xff0c;人不妄动&#xff0c;不动则不伤&#xff1b;如心动则人妄动&#xff0c;伤其身痛其骨&#xff0c;于是体会到世间诸般痛苦。 1、购物车需求 1&#xff09;、需求描述&#xff1a; - 用户可以在登录状态下将商品添加到购…

【项目】---快速搜索工具

目录 一、项目背景 二、项目需求分析 三、项目涉及的知识点 四、项目实现的基础理论 五、项目框架 六、增加系统工具模块 6.1、扫描本地的文件的功能 七、增加数据管理模块 7.1、先了解数据库sqlite 7.2 封装sqlite数据库管理类 7.3、封装数据管理类 7.3.1增加搜索…

成都女子情人节给东莞男子送巧克力,却被后者典当后换成望京卡牌

一年一度的情人节已经来临&#xff0c;每年的这个时候&#xff0c;都是少男少女们欢庆的节日&#xff0c;因为他们可以借助送礼物&#xff0c;各自表达对另一半的爱慕之情。然而由于中国人的传统观念&#xff0c;一般都是男方给女方送礼物&#xff0c;女方给男方送礼物的就凤毛…

宝塔搭建实战php开源likeadmin通用管理移动端uniapp源码(四)

大家好啊&#xff0c;我是测评君&#xff0c;欢迎来到web测评。 上一期给大家分享了pc端的部署方式&#xff0c;今天来给大家分享uniapp端在本地搭建&#xff0c;与打包发布到宝塔的方法。感兴趣的朋友可以自行下载学习。 技术架构 vscode node16 vue3 uniapp vite types…

PageHelper分页查询

分页查询分页查询的优点所谓分页,就是查询结果数据较多时,采用按页显示的方法,而不是一次性全部显示分页的优点:服务器:一次性查询所有信息,服务器压力大,分页查询服务器压力小客户端:一次性显示所有信息,需要更多流量,加载时间也会更长,分页显示没有这个问题用户体验上:一般最…

Hot 100 | 287. 寻找重复数

LeetCode 287. 寻找重复数 给定一个包含 n 1 个整数的数组 nums &#xff0c;其数字都在 [1, n] 范围内&#xff08;包括 1 和 n&#xff09;&#xff0c;可知至少存在一个重复的整数。假设 nums 只有 一个重复的整数 &#xff0c;返回 这个重复的数 。 你设计的解决方案必须&…

【Spring Cloud Alibaba】(三)OpenFeign扩展点实战 + 源码详解

系列目录 【Spring Cloud Alibaba】&#xff08;一&#xff09;微服务介绍 及 Nacos注册中心实战 【Spring Cloud Alibaba】&#xff08;二&#xff09;微服务调用组件Feign原理实战 本文目录系列目录前言一、Feign扩展点配置二、OpenFeign扩展点配置1. 通过配置文件配置有效范…