logologo
Empezar
Manual
Desarrollo
Plugins
API
Inicio
English
简体中文
日本語
한국어
Español
Português
Deutsch
Français
Русский
Empezar
Manual
Desarrollo
Plugins
API
Inicio
logologo
Descripción general de RunJS
Importación de módulos
Renderizado en contenedor

Variables globales

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 PageDescripción general de RunJS
Aviso de traducción IA

Este documento ha sido traducido por IA. Para información precisa, consulte la versión en inglés.

#Introducción a RunJS

RunJS es el entorno de ejecución de JavaScript utilizado en NocoBase para escenarios como bloques JS, campos JS y acciones JS. El código se ejecuta en un entorno aislado (sandbox) restringido, proporcionando acceso seguro a ctx (API de contexto) e incluye las siguientes capacidades:

  • await de nivel superior (Top-level await)
  • Importación de módulos externos
  • Renderizado dentro de contenedores
  • Variables globales

#await de nivel superior (Top-level await)

RunJS admite await de nivel superior, eliminando la necesidad de envolver el código en una IIFE.

No recomendado

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

Recomendado

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

#Importación de módulos externos

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

#Renderizado dentro de contenedores

Utilice ctx.render() para renderizar contenido en el contenedor actual (ctx.element). Admite los siguientes tres formatos:

#Renderizar JSX

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

#Renderizar nodos DOM

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

ctx.render(div);

#Renderizar cadenas HTML

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

#Variables globales

  • window
  • document
  • navigator
  • ctx