Este documento ha sido traducido por IA. Para información precisa, consulte la versión en inglés.
JS Action
Introducción
JS Action se utiliza para ejecutar JavaScript al hacer clic en un botón para personalizar cualquier comportamiento de negocio. Puede utilizarse en barras de herramientas de formularios, barras de herramientas de tablas (nivel de colección), filas de tablas (nivel de registro), entre otros, para realizar validaciones, avisos, llamadas a la interfaz, abrir ventanas emergentes/cajones, actualizar datos, etc.

API del contexto en tiempo de ejecución (Uso común)
-
ctx.api.request(options): Realiza una solicitud HTTP; -
ctx.openView(viewUid, options): Abre una vista configurada (cajón/diálogo/página); -
ctx.message/ctx.notification: Avisos y notificaciones globales; -
ctx.t()/ctx.i18n.t(): Internacionalización; -
ctx.resource: Recurso de datos del contexto a nivel de colección (como la barra de herramientas de la tabla, incluyegetSelectedRows(),refresh(), etc.); -
ctx.record: Registro de la fila actual del contexto a nivel de registro (como botones de fila de tabla); -
ctx.form: Instancia de AntD Form del contexto a nivel de formulario (como botones de barra de herramientas de formulario); -
ctx.collection: Metainformación de la colección actual; -
El editor de código admite fragmentos
Snippetsy pre-ejecuciónRun(ver más abajo). -
ctx.requireAsync(url): Carga de forma asíncrona librerías AMD/UMD por URL; -
ctx.importAsync(url): Importa dinámicamente módulos ESM por URL; -
ctx.libs.React/ctx.libs.ReactDOM/ctx.libs.antd/ctx.libs.antdIcons/ctx.libs.dayjs/ctx.libs.lodash/ctx.libs.math/ctx.libs.formula: Librerías comunes integradas como React / ReactDOM / Ant Design / Iconos de Ant Design / dayjs / lodash / math.js / formula.js, utilizadas para renderizado JSX, procesamiento de tiempo, manipulación de datos y operaciones matemáticas.
Las variables disponibles variarán según la ubicación del botón; lo anterior es un resumen de las capacidades comunes.
Editor y fragmentos
Snippets: Abre la lista de fragmentos de código integrados, permite buscar e insertar con un clic en la posición actual del cursor.Run: Ejecuta directamente el código actual y muestra los registros de ejecución en el panel inferiorLogs; admiteconsole.log/info/warn/errory localización de errores con resaltado.

- Puede combinarse con empleados de IA para generar/modificar scripts: Empleado de IA · Nathan: Ingeniero Frontend
Uso común (Ejemplos simplificados)
1) Solicitud a la interfaz y avisos
2) Botón de colección: Validar selección y procesar
3) Botón de registro: Leer el registro de la fila actual
4) Abrir vista (Cajón/Diálogo)
5) Actualizar datos tras el envío
Notas
- Idempotencia del comportamiento: Evite envíos múltiples causados por clics repetidos; puede añadir un interruptor de estado o desactivar el botón en la lógica.
- Manejo de errores: Añada try/catch a las llamadas de interfaz y proporcione avisos al usuario.
- Vinculación de vistas: Al abrir ventanas emergentes/cajones a través de
ctx.openView, se recomienda pasar parámetros de forma explícita y, si es necesario, actualizar activamente el recurso padre tras un envío exitoso.

