sublime如何自定义右键菜单添加常用命令? (Context.sublime-menu)

发布时间 - 2025-12-29 00:00:00    点击率:
Sublime Text 右键菜单可通过编辑 User/Context.sublime-menu 文件自定义,需按系统路径手动创建 UTF-8 编码的 JSON 格式文件,利用 context 字段精准控制命令在文本区、侧边栏等不同位置的显示条件。

Sublime Text 的右键菜单(上下文菜单)可以通过编辑 Context.sublime-menu 文件来自定义,添加常用命令(比如格式化、复制路径、运行脚本等)。这个文件控制的是在编辑器内**文本区域、侧边栏、标签页等不同位置**点击右键时显示的选项。

找到并创建 Context.sublime-menu 文件

Sublime 默认没有提供该文件,需要手动创建。路径取决于你的系统和 Sublime 版本(以 Sublime Text 4 为例):

  • Windows%APPDATA%\Sublime Text\Packages\User\Context.sublime-menu
  • macOS~/Library/Application Support/Sublime Text/Packages/User/Context.sublime-menu
  • Linux~/.config/sublime-text/Packages/User/Context.sublime-menu

如果 User 文件夹下没有 Context.sublime-menu,就新建一个纯文本文件,保存为该名字,编码选 UTF-8,确保后缀是 .sublime-menu(不是 .txt)。

理解菜单结构和作用域

这个文件是 JSON 格式数组,每一项是一个菜单项对象。关键字段有:

  • caption:菜单上显示的文字(支持 & 快捷键,如 "&Format" 显示为 Format)
  • command:要执行的命令名(比如 "toggle_comment""reindent"
  • args:传递给命令的参数(可选)
  • context:控制该菜单项在哪种场景下出现(非常重要!)

context 是个数组,每个元素含 keyoperator(如 "equal")、operand(值),常见判断条件:

  • {"key": "selector", "operator": "equal", "operand": "source.python"} → 只在 Python 文件中显示
  • {"key": "selection_empty", "operator": "equal", "operand": true} → 无选中文本时才显示
  • {"key": "side_bar", "operator": "equal", "operand": true} → 右键点在侧边栏时生效
  • {"key": "file_name", "operator": "regex_contains", "operand": "\\.py$"} → 文件名匹配正则时显示

添加几个实用命令示例

以下是一个精简但常用的 Context.sublime-menu 示例内容(可直接复制使用):

[
  { "caption": "-",
    "command": "dummy" },
  { "caption": "Format Code",
    "command": "reindent",
    "args": {"single_line": false},
    "context": [
      {"key": "selector", "operator": "not_equal", "operand": "source"},
      {"key": "selection_empty", "operator": "equal", "operand": true}
    ]
  },
  { "caption": "Toggle Comment",
    "command": "toggle_comment",
    "args": {"block": false}
  },
  { "caption": "Copy File Path",
    "command": "copy_path"
  },
  { "caption": "Open Containing Folder",
    "command": "open_dir",
    "args": {"dir": "$file_path"},
    "context": [{"key": "file_name", "operator": "not_equal", "operand": ""}]
  }
]

说明:

  • "-" 是分隔线(用 dummy 命令占位)
  • reindent 在非 source 模式且无选中时格式化全文(避免误触)
  • copy_pathopen_dir 需要当前有打开的文件(靠 file_name 判断)
  • 所有命令名必须拼写正确,可通过 Command Palette → “Developer: Show All Commands” 查看支持的命令列表

调试与生效技巧

改完保存后,右键菜单不会自动刷新。可以:

  • 重启 Sublime Text(最稳妥)
  • 或按 Ctrl+Shift+P(Win/Linux) / Cmd+Shift+P(macOS),输入 “Satisfy Dependencies” 并回车(部分插件触发重载)
  • 如果菜单不出现,打开 Console(View → Show Console),看是否有 JSON 解析错误(比如逗号多写、引号不匹配)
  • 想快速测试 context 是否生效?先加一条简单项,比如只带 "caption": "TEST""command": "echo"(需自定义 echo 命令),再逐步加条件

基本上就这些。不需要插件,纯配置就能让右键更顺手。关键是理解 context 规则——不然命令可能一直不显示,或者到处乱冒。


# linux  # python  # sublime  # js  # json  # windows  # 编码  # app  # mac  # ai  # macos  # win 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  详解阿里云nginx服务器多站点的配置  Laravel如何自定义分页视图?(Pagination示例)  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  如何用PHP快速搭建CMS系统?  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  深入理解Android中的xmlns:tools属性  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  如何在腾讯云免费申请建站?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  javascript基于原型链的继承及call和apply函数用法分析  Python数据仓库与ETL构建实战_Airflow调度流程详解  如何在自有机房高效搭建专业网站?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  如何在Windows虚拟主机上快速搭建网站?  原生JS获取元素集合的子元素宽度实例  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  如何在IIS中新建站点并配置端口与物理路径?  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Python文件异常处理策略_健壮性说明【指导】  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  如何在云主机上快速搭建多站点网站?  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  如何做网站制作流程,*游戏网站怎么搭建?  电商网站制作价格怎么算,网上拍卖流程以及规则?  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  如何正确选择百度移动适配建站域名?  Android Socket接口实现即时通讯实例代码  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  *服务器网站为何频现安全漏洞?  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  Laravel如何发送系统通知?(Notification渠道示例)  昵图网官方站入口 昵图网素材图库官网入口  如何在建站之星绑定自定义域名?  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  进行网站优化必须要坚持的四大原则  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  音乐网站服务器如何优化API响应速度?  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  PHP 500报错的快速解决方法  如何快速搭建高效服务器建站系统?