首页
/ 在@antfu/eslint-config中集成@tanstack/eslint-plugin-query的实践指南

在@antfu/eslint-config中集成@tanstack/eslint-plugin-query的实践指南

2025-06-09 14:53:26作者:谭伦延

背景介绍

在现代前端开发中,ESLint作为代码质量保障工具已经成为了项目标配。@antfu/eslint-config是antfu团队提供的一套开箱即用的ESLint配置方案,它集成了多种流行的代码规范和风格检查规则。而@tanstack/query(原react-query)作为React生态中优秀的数据获取库,其官方也提供了对应的ESLint插件@tanstack/eslint-plugin-query来帮助开发者更好地使用该库。

问题场景

许多开发者在从传统ESLint配置迁移到@antfu/eslint-config的扁平化配置(flat config)时,会遇到如何正确集成第三方插件的问题。特别是对于@tanstack/eslint-plugin-query这样的插件,其配置方式与传统ESLint有所不同。

解决方案

方法一:直接扩展插件配置

最直接的方式是在antfu配置后直接扩展插件的推荐配置:

import antfu from '@antfu/eslint-config'
import pluginQuery from '@tanstack/eslint-plugin-query'

export default antfu(
  {
    // antfu的基础配置
    formatters: true,
    react: true,
    stylistic: {
      indent: 2,
      semi: true,
      quotes: 'single',
    }
  },
  // 扩展query插件的推荐配置
  pluginQuery.configs['flat/recommended']
)

这种方式保持了配置的简洁性,同时确保了query插件的所有推荐规则都能生效。

方法二:合并多个配置对象

如果需要更细粒度的控制,可以采用配置对象合并的方式:

export default antfu(
  {
    // antfu基础配置
    ...
  },
  {
    // query插件配置
    ...pluginQuery.configs['flat/recommended'],
    // 其他自定义规则
    rules: {
      '@tanstack/query/exhaustive-deps': 'error',
      // 覆盖或添加其他规则
    }
  }
)

注意事项

  1. 插件加载顺序:在扁平化配置中,配置对象的顺序很重要,后面的配置会覆盖前面的同名规则。

  2. 规则优先级:如果antfu的默认配置中已经包含了某些与query插件冲突的规则,需要通过显式配置来调整优先级。

  3. TypeScript支持:如果项目使用TypeScript,确保query插件的TypeScript相关规则也能正确加载。

  4. React项目:对于React项目,建议同时配置react和query插件,以获得最佳开发体验。

最佳实践

对于大多数项目,推荐采用第一种简洁的配置方式。只有在需要特别定制某些规则时,才考虑第二种更详细的配置方法。无论采用哪种方式,都建议在配置完成后运行ESLint的--fix选项,并检查是否有预期外的规则冲突。

通过合理配置,开发者可以充分利用@antfu/eslint-config提供的便利性,同时又能享受到@tanstack/eslint-plugin-query带来的专业检查能力,从而提升代码质量和开发效率。

登录后查看全文

项目优选

收起
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
295
946
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
490
393
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
111
195
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
59
140
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
356
321
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
51
14
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
97
251
ArkAnalyzer-HapRayArkAnalyzer-HapRay
ArkAnalyzer-HapRay 是一款专门为OpenHarmony应用性能分析设计的工具。它能够提供应用程序性能的深度洞察,帮助开发者优化应用,以提升用户体验。
Python
18
6
arkanalyzerarkanalyzer
方舟分析器:面向ArkTS语言的静态程序分析框架
TypeScript
32
38
CangjieMagicCangjieMagic
基于仓颉编程语言构建的 LLM Agent 开发框架,其主要特点包括:Agent DSL、支持 MCP 协议,支持模块化调用,支持任务智能规划。
Cangjie
579
41