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

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

#ctx.initResource()

Inicializa o recurso (resource) para o contexto atual. Se ctx.resource ainda não existir, ele cria um do tipo especificado e o vincula ao contexto; se já existir, ele é usado diretamente. Depois disso, ele pode ser acessado via ctx.resource.

#Cenários de uso

Geralmente usado em cenários de JSBlock (bloco independente). A maioria dos blocos, popups e outros componentes já possuem o ctx.resource pré-vinculado e não exigem chamadas manuais. O JSBlock não possui recurso por padrão, portanto, você deve chamar ctx.initResource(type) antes de carregar dados via ctx.resource.

#Definição de Tipo

initResource(
  type: 'APIResource' | 'SingleRecordResource' | 'MultiRecordResource' | 'SQLResource'
): FlowResource;
ParâmetroTipoDescrição
typestringTipo de recurso: 'APIResource', 'SingleRecordResource', 'MultiRecordResource', 'SQLResource'

Retorno: A instância do recurso no contexto atual (ou seja, ctx.resource).

#Diferença de ctx.makeResource()

MétodoComportamento
ctx.initResource(type)Cria e vincula se ctx.resource não existir; retorna o existente se já houver um. Garante que ctx.resource esteja disponível.
ctx.makeResource(type)Apenas cria e retorna uma nova instância, não escreve em ctx.resource. Adequado para cenários que exigem múltiplos recursos independentes ou uso temporário.

#Exemplos

#Dados de Lista (MultiRecordResource)

ctx.initResource('MultiRecordResource');
ctx.resource.setResourceName('users');
await ctx.resource.refresh();
const rows = ctx.resource.getData();
ctx.render(<pre>{JSON.stringify(rows, null, 2)}</pre>);

#Registro Único (SingleRecordResource)

ctx.initResource('SingleRecordResource');
ctx.resource.setResourceName('users');
ctx.resource.setFilterByTk(1); // Especifica a chave primária
await ctx.resource.refresh();
const record = ctx.resource.getData();

#Especificar Fonte de Dados

ctx.initResource('MultiRecordResource');
ctx.resource.setDataSourceKey('main');
ctx.resource.setResourceName('orders');
await ctx.resource.refresh();

#Observações

  • Na maioria dos cenários de blocos (Formulários, Tabelas, Detalhes, etc.) e popups, o ctx.resource já é pré-vinculado pelo ambiente de execução, portanto, chamar ctx.initResource é desnecessário.
  • A inicialização manual é necessária apenas em contextos como o JSBlock, onde não há recurso padrão.
  • Após a inicialização, você deve chamar setResourceName(name) para especificar a coleção e, em seguida, chamar refresh() para carregar os dados.

#Relacionado

  • ctx.resource — A instância do recurso no contexto atual
  • ctx.makeResource() — Cria uma nova instância de recurso sem vinculá-la ao ctx.resource
  • MultiRecordResource — Múltiplos registros/Lista
  • SingleRecordResource — Registro único
  • APIResource — Recurso de API geral
  • SQLResource — Recurso de consulta SQL