Monaco 编辑器的 YAML 语言插件。在编辑 YAML 文件时提供以下功能:
也可以通过配置提供 schemas。查看这里了解插件提供的配置 YAML 语言支持的 API。
@monaco-editor/loader
或 @monaco-editor/react
?monaco-yaml
与框架集成?(Angular、React、Vue 等)monaco-yaml
是否适用于 create-react-app
?monaco-yaml
不工作?官方 Monaco 语言扩展可以工作。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 目录中找到。
monaco-yaml
有以下导出:
configureMonacoYaml(monaco, options?)
配置 monaco-yaml
。
注意:同一时间只能有一个配置好的
monaco-yaml
实例。
monaco
(object
): Monaco 编辑器模块。通常通过导入 monaco-editor
获得。第三方集成通常将其公开为全局 monaco
变量。options
(object
): 用于配置 monaco-yaml
的选项。completion
(boolean
):如果设置,启用基于模式的自动完成。(默认:true
)customTags
(string[]
):自定义标签列表。(默认:[]
)enableSchemaRequest
(boolean
):如果设置,模式服务将按需加载模式内容。(默认:false
)format
(boolean
):来自捆绑包的Prettier。(默认:true
)hover
(boolean
):如果设置,启用基于JSON模式的悬停类型。(默认:true
)isKubernetes
(boolean
):如果为true,使用不同的diff算法生成错误消息。(默认:false
)schemas
(object[]
):已知模式和/或模式与文件名关联的列表。(默认:[]
)validate
(boolean
):基于验证。(默认:true
)yamlVersion
('1.1' | '1.2'
):用于解析的YAML版本。(默认:1.2
)可用于处置或更新monaco-yaml
的对象。
是的,从版本5.0.0开始支持。
是的,从版本5.0.0开始支持。
@monaco-editor/loader
或@monaco-editor/react
?是的,从版本5.0.0开始支持。
是的。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时遇到了以下错误:
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-editor
或yarn why monaco-editor
找出为什么安装了monaco-editor
。它应该只存在一次,但如果它被去重了也是可以的。
您可以尝试删除node_modules
文件夹和package-lock.json
或yarn.lock
,然后分别运行npm install
或yarn install
来解决这个问题。
如果您正在使用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从@microsoft的monaco-json
分叉了这个仓库,并重写它以使用yaml-language-server
。后来,仓库的维护由@pengx17接管。最终,仓库被转移到@remcohaszing的账户下,他目前正在维护这个仓库,并得到了@fleon和@yazaabed的帮助。
主要的处理工作是在yaml-language-server
中完成的,它最著名的是作为vscode-yaml
的核心。这个仓库提供了一个薄层,将yaml-language-server
提供的功能添加到monaco-editor
中。
AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限 于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩 、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖 科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。
一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型
Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号