配置
大约 3 分钟
插件配置
你可以设置以下插件选项来启用或禁用一些功能。
playground
- 类型: - PlaygroundGlobalOptions- interface PlaygroundCodeConfig { /** * 代码块扩展名 * * @description 它基于文件名,而不是代码块语言 */ ext: string; /** 代码块内容 */ content: string; } interface PlaygroundData { /** 交互演示标题 */ title?: string; /** * Import map 文件名 * * @default "import-map.json" */ importMap?: string; /** 交互演示文件信息 */ files: Record< /** 文件名 */ string, /** 文件详情 */ PlaygroundCodeConfig >; /** * 交互演示设置 * * @description 它是设置指令后的 json 内容的解析结果 */ settings: Record<string, unknown>; /** * hash key based on playground content * * 根据交互演示内容生成的 hash key */ key: string; } interface PlaygroundOptions { /** 交互演示容器名 */ name: string; /** * 交互演示组件名称 * * @default "Playground" */ component?: string; /** 属性获取器 */ propsGetter: (data: PlaygroundData) => Record<string, string>; } interface TSPresetPlaygroundOptions extends CompilerOptions { /** * 交互演示外部地址 * * @default "https://www.typescriptlang.org/play" */ service?: string; } interface VuePresetPlaygroundOptions { /** * 交互演示外部地址 * * @default "https://sfc.vuejs.org/" */ service?: string; /** * 是否启用开发版本 * * @default false */ dev?: boolean; /** * 是否启用 SSR * * @default false */ ssr?: boolean; } interface UnoPresetPlaygroundOptions { /** * 交互演示外部地址 * * @default "https://unocss.dev/play" */ service?: string; } type BuiltInPlaygroundPreset = "ts" | "vue" | "unocss"; interface PlaygroundGlobalOptions { /** 交互演示预设 */ presets: (BuiltInPlaygroundPreset | PlaygroundOptions)[]; /** 交互演示配置 */ config?: { ts?: TSPresetPlaygroundOptions; vue?: VuePresetPlaygroundOptions; unocss?: UnoPresetPlaygroundOptions; }; }
- 必填: 否 
- 详情: 
交互演示选项。
kotlinPlayground
- 类型: boolean
- 默认值: false
- 详情:
是否启用 Kotlin 交互演示支持。
vuePlayground
- 类型: boolean
- 默认值: false
- 详情:
是否启用 Vue 交互演示支持。
demo
- 类型: CodeDemoGlobalOptions | boolean
- 默认值: false
- 详情:
是否启用代码案例支持。
demo.jsLib
- 类型: string[]
- 必填: 否
CodePen, JsFiddle 需要引入的外部 JS 库。
demo.cssLib
- 类型: string[]
- 必填: 否
CodePen, JsFiddle 需要引入的外部 CSS 库。
注意
上述两个选项仅仅是给第三方代码演示使用的,你需要自行在 head 中导入这些库。
demo.jsfiddle
- 类型: boolean
- 默认值: true
是否显示 JSFiddle 按钮
demo.codepen
- 类型: boolean
- 默认值: true
是否显示 CodePen 按钮
demo.codepenLayout
- 类型: "top" | "left" | "right"
- 默认值: "left"
CodePen 编辑器布局
demo.codepenEditors
- 类型: string
- 默认值: "101"
CodePen 编辑器状态
demo.editors
- 类型: string
- 默认值: "101"
CodePen 编辑器显示情况,第一位代表 HTML ,第二位代表 JS,第三位代表演示页面。
其他
以下是第三方代码演示使用的库地址,除非你的环境无法访问 unpkg 或访问缓慢,否则无需覆盖默认设置。
demo.babel
默认值: "https://unpkg.com/@babel/standalone/babel.min.js"
demo.vue
默认值: "https://unpkg.com/vue/dist/vue.global.prod.js"
demo.react
默认值: "https://unpkg.com/react/umd/react.production.min.js"
demo.reactDOM
默认值: "https://unpkg.com/react-dom/umd/react-dom.production.min.js"
sandpack
- 类型: boolean
- 默认值: false
是否启用 Sandpack 交互演示。
客户端配置
defineKotlinPlaygroundConfig
interface KotlinPlaygroundOptions {
  server?: string;
  version?: string;
  onChange?: (code: string) => void;
  onRun?: () => void;
  onError?: () => void;
  getJsCode?: (code: string) => void;
  onTestPassed?: () => void;
  onTestFailed?: () => void;
  onOpenConsole?: () => void;
  onCloseConsole?: () => void;
  callback?: (targetNode: HTMLElement, mountNode: HTMLElement) => void;
  getInstance?: (instance: KotlinPlaygroundInstance) => void;
}
const defineKotlinPlaygroundConfig: (options: KotlinPlaygroundOptions) => void;定义需要传递给 kotlin-playground 的配置选项。
defineSandpackConfig
 interface SandpackConfig {
  /**
   * 指定模板
   */
  template?: SandpackPredefinedTemplate;
  /**
   * sandpack 配置项
   */
  options?: SandpackOptions;
  /**
   * sandpack customSetup 配置项
   */
  customSetup?: SandpackSetup;
}
const defineSandpackConfig = (config: SandpackConfig)=> void定义需要传递给 sandpack-vue3 的选项。
defineVuePlaygroundConfig
export interface VuePlaygroundOptions
  extends Omit<ReplProps, "store" | "editor"> {
  /**
   * 指定 vue 版本
   */
  vueVersion?: string;
  /**
   * 指定默认的 Vue 开发运行时
   *
   * @default "https://unpkg.com/@vue/runtime-dom@${version}/dist/runtime-dom.esm-browser.js"
   */
  vueRuntimeDevUrl?: string | (() => string);
  /**
   * 指定默认的 Vue 生产运行时
   *
   * @default "https://unpkg.com/@vue/runtime-dom@${version}/dist/runtime-dom.esm-browser.prod.js"
   */
  vueRuntimeProdUrl?: string | (() => string);
  /**
   * 指定默认的 Vue 服务端渲染器
   *
   * @default "https://unpkg.com/@vue/server-renderer@${version}/dist/server-renderer.esm-browser.js"
   */
  vueServerRendererUrl?: string | (() => string);
}
const defineVuePlaygroundConfig: (options: VuePlaygroundOptions) => void;定义需要传递给 @vue/repl 的选项。
更新日志
2025/6/18 10:11
查看所有更新日志
- 660a5-于
- c9017-于
- 70692-于
- 22787-于
- 99f51-于
- 6ad69-于
- 3dcc0-于
- 913bb-于
- f0fcc-于
- 92957-于
- 8cb86-于
- d544c-于
- 95198-于
- 497db-于
- fa8af-于
- 1669d-于
- 7bc15-于
- bac94-于
- 2dbdd-于
- 55ea3-于
- f55f2-于
- 8e9aa-于
- 539b3-于
- f0736-于
- def96-于
- 254c5-于
- ef5af-于
- a648a-于
- f6ff7-于
- 573c3-于
- 16ff1-于
- d06e4-于
- a7a28-于
- 12ecd-于
- 91679-于
- d0c25-于
- 0eb18-于
- af82c-于
- edf2d-于
- 4104e-于
- 1c52f-于
- 74050-于
- c5742-于
- 1433d-于
- 6e91a-于
- b4289-于
- 6639c-于
- 8b5af-于
- 0e45a-于
- 9fcf5-于
- 23f74-于
- 3dac6-于
- feeb6-于
- 637b2-于
- 7c8cf-于
- 2fa50-于
- 1d7fa-于
- 86cc2-于
- 5498b-于
- 099d8-于
- 80eb7-于
- 57c57-于
- 48bca-于
- 63d09-于
- ad023-于
- 88e69-于
- 6d302-于
- e07b5-于
- 904c0-于
- 227bc-于
- 1d0f9-于
- 67429-于
- 4d1ba-于
- 907b9-于
- 8dc9f-于
- fca17-于
- ace60-于