0

0

sublime的语法定义文件是什么_sublime自定义语言高亮教程

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-12-08 16:31:02

|

493人浏览过

|

来源于php中文网

原创

Sublime Text的语法定义文件是基于YAML的配置文件,用于定义代码高亮规则。它通过name、file_extensions、scope和contexts等字段,指定语言名称、关联扩展名、作用域及匹配规则,利用正则表达式识别关键字、注释、字符串等元素,并结合主题文件实现着色。用户可创建.sublime-syntax文件,定义上下文与作用域,测试后实现自定义语言高亮。

sublime的语法定义文件是什么_sublime自定义语言高亮教程

Sublime Text 的语法定义文件是用来定义代码高亮规则的配置文件,通常以 .sublime-syntax 为扩展名。这类文件基于 YAML 格式编写,用于告诉 Sublime Text 如何识别某种编程语言的关键字、注释、字符串、函数等元素,并为其应用相应的颜色和样式。

一、什么是 .sublime-syntax 文件?

.sublime-syntax 是 Sublime Text 3 及以上版本使用的现代语法定义格式,取代了旧版的 .tmLanguage(基于 XML)。它结构清晰、易于编写和维护,支持正则表达式匹配和上下文切换,适合定义各种语言的高亮规则。

一个典型的语法文件包含以下内容:

  • name:语法显示名称(如 "MyLang")
  • file_extensions:关联的文件扩展名(如 mylang, ml)
  • scope:作用域名称(如 source.mylang)
  • contexts:定义匹配规则的上下文,如主上下文、注释、字符串等

二、如何创建自定义语言高亮?

下面是一个简单的步骤,教你从零开始为一种自定义语言添加语法高亮。

1. 打开语法包目录
在 Sublime Text 中:

  • 菜单栏选择 Preferences → Browse Packages…
  • 进入后新建一个文件夹,比如命名为 MyCustomLang

2. 创建 .sublime-syntax 文件
在该文件夹中新建文件:MyLang.sublime-syntax

3. 编写基础语法定义
示例:为一种叫 MyLang 的简单语言定义高亮

%
YAML 1.2
---
name: MyLang
file_extensions: [mylang]
scope: source.mylang

contexts: main:

  • match: '#.*$' scope: comment.line.number-sign

  • match: '\b(if|else|while|func)\b' scope: keyword.control.mylang

  • match: '"[^"]*"' scope: string.quoted.double.mylang

  • match: '\b(true|false|null)\b' scope: constant.language.mylang

  • match: '\b\d+\b' scope: constant.numeric.mylang

4. 解释关键字段

wechat-miniprogram-plugin
wechat-miniprogram-plugin

wechat-miniprogram-plugin是基于JetBrains平台的微信小程序插件。主要功能wxml/wxss/wxs文件支持语法解析代码完成代码高亮wxml嵌入表达式支持wxml 标签支持wxml提取自定义组件创建微信小程序组件以及页面相关文件导航微信小程序自定义组件支持自动注册自定义组件组件配置解析重命名小程序自定义组件或页面同时移动自定义组件或页面的所有文件微信小程序配置文件支持

下载
  • match:使用正则表达式匹配文本
  • scope:指定匹配内容的作用域,决定颜色主题如何着色
  • contexts:可以定义多个上下文,比如 main 是入口点,还可定义 string_context 等嵌套状态

三、作用域(Scope)与主题配合

语法文件只负责“标记”文本属于什么类型,真正决定颜色的是当前使用的 Color Scheme(主题文件,通常是 .tmTheme 或 .sublime-color-scheme)。

例如,如果你设置了 keyword.control.mylang,主题中需要有对应的作用域样式才能看到高亮效果。大多数主题已预定义常见作用域(如 keyword、string、comment),因此一般无需额外设置。

四、测试与调试

  • 保存文件后,打开一个 .mylang 后缀的文件,查看是否自动应用语法
  • 可通过菜单 View → Syntax → MyLang 手动切换
  • 使用 Tools → Developer → Show Scope Name 查看光标处的作用域,确认匹配是否正确

五、进阶功能

  • 嵌套上下文:可用于处理多行字符串或嵌套注释
  • push / pop / clear:控制上下文,实现复杂状态切换
  • with_prototype:在进入某个上下文前先加载一组规则

例如,进入多行字符串:

    - match: '«'
      push: triple-string-context
      set:
        - match: '»'
          pop: true
        - match: '\n'
          scope: invalid.illegal.newline

六、参考资源

基本上就这些。写一个基础的语法文件不难,关键是理解上下文和作用域机制。只要会正则,就能快速上手自定义语言高亮。

相关专题

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

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

759

2023.06.15

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

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

639

2023.07.20

python能做什么
python能做什么

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

762

2023.07.25

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

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

618

2023.07.31

python教程
python教程

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

1265

2023.08.03

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

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

549

2023.08.04

python eval
python eval

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

579

2023.08.04

scratch和python区别
scratch和python区别

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

709

2023.08.11

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

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

精品课程

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

共58课时 | 3.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

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

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