0

0

VSCode选择范围提供者实现

狼影

狼影

发布时间:2025-10-20 16:56:01

|

315人浏览过

|

来源于php中文网

原创

Selection Range Provider是VSCode中用于实现层级化代码选择的API,通过注册provideSelectionRanges方法,按光标位置从内到外逐层扩展选择范围,如从变量名扩展至函数体;需结合AST解析构建准确的SelectionRange链式结构以提升选择智能性。

vscode选择范围提供者实现

在 VSCode 中实现选择范围提供者(Selection Range Provider),主要是为了让编辑器能够根据光标位置,智能地扩展选择范围。比如从一个变量名逐步扩展到语句、代码块、函数体甚至整个文件。这个功能在双击或连续按 Ctrl+Shift+→ 时特别有用。

什么是 Selection Range Provider?

Selection Range Provider 是 VSCode 语言扩展中的一个 API,允许你自定义代码中“层级化选择”的逻辑。它返回一个从当前位置向外逐层扩大的范围数组,每一层都比上一层更大。

要实现这个功能,你需要注册 SelectionRangeProvider 并实现其 provideSelectionRanges 方法。

如何注册 Selection Range Provider

在你的扩展的 extension.ts 文件中,使用 languages.registerSelectionRangeProvider 注册提供者:

vscode.languages.registerSelectionRangeProvider('javascript', {
    provideSelectionRanges(document, positions, token) {
        const ranges = positions.map(position => {
            // 返回每个 position 对应的选择范围链
            return buildSelectionRanges(document, position);
        });
        return ranges;
    }
});

上面的 'javascript' 可以替换为你的语言标识,比如 myLang,也可以传入一个 LanguageSelector。

实现 provideSelectionRanges 方法

核心是构建从光标位置开始,逐层外扩的范围链。每层是一个 SelectionRange,包含当前范围和父级范围。

示例:简单基于括号和行边界构建层级:

function buildSelectionRanges(document: vscode.TextDocument, position: vscode.Position): vscode.SelectionRange[] {
    const ranges: vscode.SelectionRange[] = [];
    let start = position;
    let end = position;
// 向前查找最近的开始边界(如 {, (, 行首)
// 向后查找结束边界(如 }, ), 行尾)
// 这里简化处理:逐行扩展

while (start.line > 0 && end.line < document.lineCount - 1) {
    const lineRange = document.lineAt(start.line).range;
    const currentRange = new vscode.Range(
        start.translate(0, -1).isBefore(lineRange.start) ? lineRange.start : start.translate(0, -1),
        end.translate(0, 1).isAfter(lineRange.end) ? lineRange.end : end.translate(0, 1)
    );

    ranges.push(new vscode.SelectionRange(currentRange));

    // 扩展到更大的上下文(比如整个函数)
    // 实际项目中应结合 AST 解析更准确
    start = start.translate(-1, 0);
    end = end.translate(1, 0);
}

// 最外层:整个文档
ranges.push(new vscode.SelectionRange(new vscode.Range(
    new vscode.Position(0, 0),
    document.lineAt(document.lineCount - 1).range.end
)));

return ranges;

}

衣购网站项目(三层开发)源码
衣购网站项目(三层开发)源码

商品查询功能提供了一个快速查看商品的途径。商品查询分为基本查询和高级查询。基本查询:提供关键字和商品大类两种条件的查询,用户可以只填写关键字或者选择商品大类或者关键字和商品大类都填写来查询商品。高级查询:提供关键字,商品大类,商品小类,商品价格范围四种条件的查询,用户可以任意填写其中一种或几种的查询条件来查询想要了解的商品信息。商品查询功能大大的方便了用户,提高了网站的用户体验。(5)帮助系统模块

下载

注意:SelectionRange 是链式结构,实际应通过 parent 字段连接,而不是直接返回数组。正确写法:

let parent: vscode.SelectionRange | undefined = undefined;
for (const range of ranges.reverse()) {
    parent = new vscode.SelectionRange(range, parent);
}
return [parent]; // 注意返回的是最外层作为根

结合语言解析提升准确性

如果只是按行或字符扩展,效果有限。建议结合语法树(AST)来识别代码结构。

例如使用 Tree-sitter 或语言自带的 parser(如 TypeScript 的语言服务),找到光标所在节点,然后逐层向上返回其父节点的范围。

步骤如下:

  • 解析文档生成 AST
  • 找到包含光标位置的最深节点
  • 沿着父节点一路向上,每个节点生成一个 Range
  • 构造 SelectionRange 链并返回

这样能实现从变量 → 表达式 → 语句 → 代码块 → 函数的自然选择流程。

基本上就这些。实现 Selection Range Provider 能显著提升编辑体验,尤其对结构化语言非常实用。关键在于理解层级关系,并合理构造 parent 链。不复杂但容易忽略细节。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
vscode
vscode

VS Code(Visual Studio Code)是一款免费、开源的跨平台代码编辑器,由微软开发和维护。它被广泛用于软件开发和编程,支持多种编程语言和框架。VS Code 同时提供了丰富的功能和扩展性,使开发者可以高效地编写、编辑和调试代码。

592

2023.06.30

vscode怎么运行代码
vscode怎么运行代码

vscode是一个运行于MacOS X、Windows和Linux之上的,针对于编写现代Web和云应用的跨平台源代码编辑器;vscode免费而且功能强大,对JavaScript和NodeJS的支持非常好,自带很多功能,例如代码格式化,代码智能提示补全、Emmet插件等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

223

2023.07.21

vscode使用的框架介绍
vscode使用的框架介绍

VSCode是一款跨平台代码编辑器,它基于Electron框架和Monaco Editor构建。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

393

2024.03.14

vscode一般用来写什么语言
vscode一般用来写什么语言

VSCode是一款功能强大的代码编辑器,支持多种编程语言和文件格式。它内置对 JavaScript、Python、Java、C++、TypeScript、HTML/CSS、Go 等语言的支持。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

379

2024.03.14

vscode可以写什么语言
vscode可以写什么语言

vscode是一款强大的代码编辑器,支持多种编程语言的开发。通过安装扩展,可以为 JavaScript/TypeScript、Python、Java、C#、PHP、Go、Ruby、Rust、HTML/CSS 等语言提供智能代码补全、调试和格式化等功能。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

553

2024.03.15

vscode中文设置方法
vscode中文设置方法

方法一:在设置页面中,搜索“locale”,并选择“zh-cn”。方法二:按“Ctrl Shift P”快捷键,输入“Configure Display Language”,将语言修改为“zh-cn”。如果上述方法无效,可考虑安装中文插件。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

555

2024.03.15

vscode用途介绍
vscode用途介绍

Visual Studio Code(VSCode)是一款由 Microsoft 开发的多功能文本编辑器,适用于各种编程语言。作为一款开源软件,VSCode 拥有代码高亮、自动补全、调试、Git 集成等强大功能,成为程序员不可或缺的工具。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

501

2024.03.15

vscode和visualstudio的区别
vscode和visualstudio的区别

Visual Studio是一款功能强大的集成开发环境(IDE),适用于专业开发人员进行复杂项目的构建。而VSCode则是一款轻量级的代码编辑器,更适合各种规模的项目开发。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

507

2024.03.15

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

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

精品课程

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

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

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

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