0

0

Sublime进行静态类型代码生成_从GraphQL Schema生成TypeScript类型定义

穿越時空

穿越時空

发布时间:2026-01-04 19:21:09

|

315人浏览过

|

来源于php中文网

原创

Sublime Text 可通过插件与外部工具链实现 GraphQL Schema 到 TypeScript 类型的生成,核心是使用 graphql-codegen 配合 Sublime 的 Build System 一键触发类型生成,并辅以 ignore 配置、自动构建和语法高亮提升开发体验。

sublime进行静态类型代码生成_从graphql schema生成typescript类型定义

Sublime Text 本身不内置 GraphQL Schema 到 TypeScript 类型的生成能力,但可以通过插件 + 外部工具链实现高效静态类型代码生成。核心思路是:用命令行工具(如 graphql-codegen)生成类型,再在 Sublime 中一键触发或快速查看/刷新。

安装并配置 graphql-codegen

这是最主流、维护活跃的方案,支持从本地 .graphql 文件或远程/本地 schema.json 生成精准的 TypeScript 类型和 Hooks。

  • 项目根目录初始化:npm init -y && npm install --save-dev @graphql-codegen/cli @graphql-codegen/typescript @graphql-codegen/typescript-operations @graphql-codegen/typescript-react-query
  • 运行 npx graphql-codegen init,按提示选择 TypeScript、schema 文件位置(如 schema.json)、操作文件(src/**/*.graphql)、输出路径(如 src/generated/graphql.ts
  • 生成 codegen.yml 后,添加常用配置项:
    generates:
      src/generated/graphql.ts:
        plugins:
          - typescript
          - typescript-operations
          - typescript-react-query
        config:
          skipTypename: true
          dedupeOperationSuffix: true

在 Sublime 中集成生成命令

无需复杂插件,用 Sublime 的 Build System 即可绑定 graphql-codegen

  • 菜单 → Tools → Build System → New Build System…
  • 粘贴以下内容(适配你的项目路径和 Node 环境):
{
"shell_cmd": "cd $project_path && npx graphql-codegen --config codegen.yml",
"file_regex": "^(...*?):([0-9]*):?([0-9]*)",
"working_dir": "$project_path",
"selector": "source.js, source.ts"
}
  • 保存为 GraphQL Codegen.sublime-build(默认存于 Packages/User/
  • 之后按 Ctrl+Shift+B(Windows/Linux)或 Cmd+Shift+B(macOS),选该构建系统,即可一键生成类型文件

提升开发体验的小技巧

让 Sublime 更好地配合生成的类型文件工作:

佳蓝在线销售系统(创业版) 佳蓝在线销售
佳蓝在线销售系统(创业版) 佳蓝在线销售

1、对ASP内核代码进行DLL封装,从而大大提高了用户的访问速度和安全性;2、采用后台生成HTML网页的格式,使程序访问速度得到进一步的提升;3、用户可发展下级会员并在下级购买商品时获得差额利润;4、全新模板选择功能;5、后台增加磁盘绑定功能;6、后台增加库存查询功能;7、后台增加财务统计功能;8、后台面值类型批量设定;9、后台财务曲线报表显示;10、完善订单功能;11、对所有传输的字符串进行安全

下载
  • 禁用对 generated/ 目录的 lint 和格式化:在项目根目录的 .prettierignore.eslintignore 中加入 src/generated/
  • 开启自动保存后生成(可选):安装插件 SublimeOnSaveBuilder,配置其只对 .graphqlschema.json 文件变更时触发 build
  • 快速跳转类型定义:确保已安装 TypeScript​SyntaxJS Custom 插件,生成的 graphql.ts 能正确高亮、支持 Ctrl+Click 跳转字段类型

替代轻量方案:使用 graphql-schema-linter + 自定义脚本

如果不想引入完整 codegen,仅需基础接口类型(如 Query, Mutation, types),可用 Python/Node 小脚本解析 schema.json

  • graphql-jsbuildClientSchema + printSchema 提取类型结构
  • 写一个 gen-types.js,读取 schema.json,输出简洁的 export interface Query { ... }
  • 同样通过 Sublime Build System 调用该脚本,适合极简项目或临时验证

基本上就这些。Sublime 不是 IDE,但搭配好工具链,它照样能稳稳支撑类型驱动的 GraphQL 开发。关键不是“在 Sublime 里造轮子”,而是让它成为你高效调用专业工具的快捷入口。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

732

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

631

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

752

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1238

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

705

2023.08.11

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

1

2026.01.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.6万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号