monaco-yaml

monaco-yaml

Monaco编辑器YAML语言插件 增强YAML文件编辑体验

monaco-yaml为Monaco编辑器提供YAML语言支持。它具备基于JSON schema的代码补全、悬停提示、语法验证和格式化功能。此插件还支持远程schema加载、YAML锚点链接和代码折叠。通过简单配置,可显著提升YAML文件的编辑体验。monaco-yaml兼容多种前端框架,并允许自定义标签和YAML版本。

Monaco EditorYAMLmonaco-yaml语言插件代码编辑器Github开源项目

Monaco YAML

ci 工作流 npm 版本 npm 下载量 演示 netlify 状态

Monaco 编辑器的 YAML 语言插件。在编辑 YAML 文件时提供以下功能:

  • 代码补全,基于 JSON schemas 或通过查看同文件中的类似对象
  • 悬停提示,基于 JSON schemas
  • 验证:语法错误和 schema 验证
  • 使用 Prettier 进行格式化
  • 文档符号
  • 自动加载远程 schema 文件(通过启用 DiagnosticsOptions.enableSchemaRequest)
  • JSON 引用的链接
  • YAML 锚点的链接和悬停效果
  • 代码折叠

也可以通过配置提供 schemas。查看这里了解插件提供的配置 YAML 语言支持的 API。

目录

安装

npm install monaco-yaml

使用

在实现 monaco-yaml 甚至 Monaco 编辑器之前,建议了解 Monaco 编辑器的基本概念

要配置 monaco-yaml,调用 configureMonacoYaml

import * as monaco from 'monaco-editor' import { configureMonacoYaml } from 'monaco-yaml' configureMonacoYaml(monaco, { enableSchemaRequest: true, schemas: [ { // 如果打开的 YAML 文件匹配此 glob fileMatch: ['**/.prettierrc.*'], // 则会从互联网下载并使用此 schema uri: 'https://json.schemastore.org/prettierrc.json' }, { // 如果打开的 YAML 文件匹配此 glob fileMatch: ['**/person.yaml'], // 将应用以下 schema schema: { type: 'object', properties: { name: { type: 'string', description: '人的显示名称' }, age: { type: 'integer', description: '这个人多少岁?' }, occupation: { enum: ['送货员', '软件工程师', '宇航员'] } } }, // 并将 URI 链接为源 uri: 'https://github.com/remcohaszing/monaco-yaml#usage' } ] }) const prettierc = monaco.editor.createModel( 'singleQuote: true\nproseWrap: always\nsemi: yes\n', undefined, monaco.Uri.parse('file:///.prettierrc.yaml') ) monaco.editor.createModel( 'name: John Doe\nage: 42\noccupation: 海盗\n', undefined, monaco.Uri.parse('file:///person.yaml') ) monaco.editor.create(document.getElementById('editor'), { automaticLayout: true, model: prettierc })

还要确保注册 web worker。使用 Webpack 5 时,看起来像下面的代码。其他打包工具可能使用不同的语法,但思路是一样的。可以省略未使用的语言。

window.MonacoEnvironment = { getWorker(moduleId, label) { switch (label) { case 'editorWorkerService': return new Worker(new URL('monaco-editor/esm/vs/editor/editor.worker', import.meta.url)) case 'css': case 'less': case 'scss': return new Worker(new URL('monaco-editor/esm/vs/language/css/css.worker', import.meta.url)) case 'handlebars': case 'html': case 'razor': return new Worker( new URL('monaco-editor/esm/vs/language/html/html.worker', import.meta.url) ) case 'json': return new Worker( new URL('monaco-editor/esm/vs/language/json/json.worker', import.meta.url) ) case 'javascript': case 'typescript': return new Worker( new URL('monaco-editor/esm/vs/language/typescript/ts.worker', import.meta.url) ) case 'yaml': return new Worker(new URL('monaco-yaml/yaml.worker', import.meta.url)) default: throw new Error(`未知标签 ${label}`) } } }

示例

演示可在 monaco-yaml.js.org 上获得。

一些使用示例可以在 examples 目录中找到。

API

monaco-yaml 有以下导出:

configureMonacoYaml(monaco, options?)

配置 monaco-yaml

注意:同一时间只能有一个配置好的 monaco-yaml 实例。

参数

  • monaco (object): Monaco 编辑器模块。通常通过导入 monaco-editor 获得。第三方集成通常将其公开为全局 monaco 变量。
  • options (object): 用于配置 monaco-yaml 的选项。

选项

  • completionboolean):如果设置,启用基于模式的自动完成。(默认:true
  • customTagsstring[]):自定义标签列表。(默认:[]
  • enableSchemaRequestboolean):如果设置,模式服务将按需加载模式内容。(默认:false
  • formatboolean):来自捆绑包的Prettier。(默认:true
  • hoverboolean):如果设置,启用基于JSON模式的悬停类型。(默认:true
  • isKubernetesboolean):如果为true,使用不同的diff算法生成错误消息。(默认:false
  • schemasobject[]):已知模式和/或模式与文件名关联的列表。(默认:[]
  • validateboolean):基于验证。(默认:true
  • yamlVersion'1.1' | '1.2'):用于解析的YAML版本。(默认:1.2

返回值

可用于处置或更新monaco-yaml的对象。

常见问题

这是否适用于Monaco UMD捆绑包?

是的,从版本5.0.0开始支持。

这是否适用于来自CDN的Monaco编辑器?

是的,从版本5.0.0开始支持。

这是否适用于@monaco-editor/loader@monaco-editor/react

是的,从版本5.0.0开始支持。

Web Worker是否必需?

是的。Web Worker提供了monaco-yaml的核心功能。

它是否可以在没有打包工具的情况下工作?

不可以。monaco-yaml使用来自node_modules的依赖项,以便可以去重并减少您的捆绑包大小。这带来的代价是无法在没有打包工具的情况下使用它。

我如何将monaco-yaml与框架集成?(Angular、React、Vue等)

monaco-yaml仅使用Monaco编辑器。它不与任何框架绑定,只需要一个DOM节点来附加Monaco编辑器即可。请参阅Monaco编辑器示例以了解如何在项目中集成Monaco编辑器,然后按上述说明配置monaco-yaml

monaco-yaml是否适用于create-react-app

是的,但您需要执行eject操作。详情请参见#92(评论)

为什么它不适用于Vite?

一些用户在使用Vite时遇到了以下错误:

Uncaught (in promise) Error: Unexpected usage
  at EditorSimpleWorker.loadForeignModule (editorSimpleWorker.js)
  at webWorker.js

作为解决方法,在您自己的项目中创建一个名为yaml.worker.js的文件,内容如下:

import 'monaco-yaml/yaml.worker.js'

然后在您的Monaco环境getWorker函数中,引用此文件而不是直接引用monaco-yaml/yaml.worker.js

import YamlWorker from './yaml.worker.js?worker' window.MonacoEnvironment = { getWorker(moduleId, label) { switch (label) { // 处理其他情况 case 'yaml': return new YamlWorker() default: throw new Error(`Unknown label ${label}`) } } }

为什么monaco-yaml不起作用?官方Monaco语言扩展可以正常工作。

这很可能是因为monaco-yaml使用的是与您不同的monaco-editor包实例。无论是否使用monaco-editor,您都应该避免这种情况,因为这意味着您的捆绑包比需要的大得多。这可能是由以下问题之一引起的:

  • 代码拆分配置错误

    要解决这个问题,请尝试使用例如webpack-bundle-analyzer检查您的捆绑包。如果monaco-editor出现两次,这就是问题所在。解决方法取决于您的具体项目。

  • 您正在使用一个为您导入monaco-editor的包,但它使用的是不同版本。

    您可以使用npm ls monaco-editoryarn why monaco-editor找出为什么安装了monaco-editor。它应该只存在一次,但如果它被去重了也是可以的。

    您可以尝试删除node_modules文件夹和package-lock.jsonyarn.lock,然后分别运行npm installyarn install来解决这个问题。

使用Monaco webpack加载器插件

如果您正在使用monaco webpack插件,那么您可以扩展插件的配置,而不是使用上述代码。在您的webpack.config.js文件中添加以下内容:

import { MonacoWebpackPlugin } from 'monaco-editor-webpack-plugin' export default { // ...webpack配置的其余部分... plugins: [ new MonacoWebpackPlugin({ languages: ['yaml'], customLanguages: [ { label: 'yaml', entry: 'monaco-yaml', worker: { id: 'monaco-yaml/yamlWorker', entry: 'monaco-yaml/yaml.worker' } } ] }) ] }

您也可以参考示例中的完整项目。

为什么即使我提供了一个对象形式的模式,它仍然试图下载我的模式?

您可能提供了一个如下配置的模式:

{ uri: "http://example.com", fileMatch: ["file_name.yml"], schema: { $schema: "http://json-schema.org/draft-07/schema#", $id: "http://example.com", title: "placeholder title", description: "placeholder description", type: "object", properties: { name: { description: "name property description", type: "string", }, }, required: ["name"], }, }

然后您可能会惊讶地看到以下错误:

Unable to load schema from '<http://example.com>': Failed to fetch.

这是因为插件不仅使用模式URI作为下载模式的URL,还用它来确定模式名称。要修复这个问题,请将uri参数更改为http://example.com/schema-name.json

贡献

请查看我们的贡献指南

致谢

最初,@kpdecker@microsoftmonaco-json分叉了这个仓库,并重写它以使用yaml-language-server。后来,仓库的维护由@pengx17接管。最终,仓库被转移到@remcohaszing的账户下,他目前正在维护这个仓库,并得到了@fleon@yazaabed的帮助。

主要的处理工作是在yaml-language-server中完成的,它最著名的是作为vscode-yaml的核心。这个仓库提供了一个薄层,将yaml-language-server提供的功能添加到monaco-editor中。

许可证

MIT

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多