logologo
Começar
Manual
Desenvolvimento
Plugins
API
Início
English
简体中文
日本語
한국어
Español
Português
Deutsch
Français
Русский
Começar
Manual
Desenvolvimento
Plugins
API
Início
logologo
Visão geral do RunJS
Importando módulos
Renderização no contêiner

Variáveis globais

window
document
navigator

ctx

ctx.blockModel
ctx.collection
ctx.collectionField
ctx.dataSource
ctx.dataSourceManager
ctx.element
ctx.exit()
ctx.exitAll()
ctx.filterManager
ctx.form
ctx.getModel()
ctx.getValue()
ctx.getVar()
ctx.i18n
ctx.importAsync()
ctx.initResource()
ctx.libs
ctx.location
ctx.logger
ctx.makeResource()
ctx.message
ctx.modal
ctx.model
ctx.notification
ctx.off()
ctx.on()
ctx.openView()
ctx.render()
ctx.request()
ctx.requireAsync()
ctx.resource
ctx.route
ctx.router
ctx.setValue()
ctx.sql
ctx.t()
ctx.view
Next PageVisão geral do RunJS
Aviso de tradução por IA

Este documento foi traduzido por IA. Para informações precisas, consulte a versão em inglês.

#Visão Geral do RunJS

O RunJS é o ambiente de execução JavaScript usado no NocoBase para cenários como Blocos JS, Campos JS e Ações JS. O código é executado em um sandbox restrito, fornecendo acesso seguro à ctx (Context API) e inclui os seguintes recursos:

  • await de nível superior (Top-level await)
  • Importação de módulos externos
  • Renderização dentro de contêineres
  • Variáveis globais

#await de nível superior (Top-level await)

O RunJS suporta await de nível superior, eliminando a necessidade de envolver o código em uma IIFE (Immediately Invoked Function Expression).

Não recomendado

async function test() {}
(async () => {
  await test();
})();

Recomendado

async function test() {}
await test();

#Importação de módulos externos

  • Use ctx.importAsync() para módulos ESM (Recomendado)
  • Use ctx.requireAsync() para módulos UMD/AMD

#Renderização dentro de contêineres

Use ctx.render() para renderizar conteúdo no contêiner atual (ctx.element). Ele suporta os três formatos a seguir:

#Renderizando JSX

ctx.render(<button>Button</button>);

#Renderizando nós DOM

const div = document.createElement('div');
div.innerHTML = 'Hello World';

ctx.render(div);

#Renderizando strings HTML

ctx.render('<h1>Hello World</h1>');

#Variáveis globais

  • window
  • document
  • navigator
  • ctx