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
Previous Pagectx.notification
Next Pagectx.on()
Aviso de tradução por IA

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

#ctx.off()

Remove os ouvintes de eventos registrados via ctx.on(eventName, handler). É frequentemente utilizado em conjunto com ctx.on para cancelar a assinatura no momento apropriado, evitando vazamentos de memória ou gatilhos duplicados.

#Casos de Uso

CenárioDescrição
Limpeza no useEffect do ReactChamado dentro da função de limpeza (cleanup) do useEffect para remover ouvintes quando o componente é desmontado.
JSField / JSEditableFieldCancela a assinatura de js-field:value-change durante a vinculação de dados bidirecional para campos.
Relacionado a resourceCancela a assinatura de ouvintes como refresh ou saved registrados via ctx.resource.on.

#Definição de Tipo

off(eventName: string, handler: (event?: any) => void): void;

#Exemplos

#Uso pareado no useEffect do React

React.useEffect(() => {
  const handler = (ev) => setValue(ev?.detail ?? '');
  ctx.on('js-field:value-change', handler);
  return () => ctx.off('js-field:value-change', handler);
}, []);

#Cancelando a assinatura de eventos de recurso

const handler = () => { /* ... */ };
ctx.resource?.on('refresh', handler);
// No momento apropriado
ctx.resource?.off('refresh', handler);

#Observações

  1. Referência consistente do handler: O handler passado para ctx.off deve ser a mesma referência utilizada em ctx.on; caso contrário, ele não poderá ser removido corretamente.
  2. Limpeza oportuna: Chame ctx.off antes que o componente seja desmontado ou o contexto seja destruído para evitar vazamentos de memória.

#Documentos Relacionados

  • ctx.on - Inscrever-se em eventos
  • ctx.resource - Instância de recurso e seus métodos on/off