Carregando dados de uma API a partir do browser

Version: 1.0.0

Leitura sugerida

A Invocação de funções client-side é um recurso poderoso do live.ts que permite que você obtenha dados diretamente dos seus funções sem enviar JavaScript para o navegador. Esse recurso garante que sua obtenção de dados seja única em todo o seu repositório e ajuda a reduzir a latência do lado do cliente.

Para começar a usar a Invocação de funções client-side, siga estes passos:

  1. Importe o objeto invoke do arquivo runtime.ts

  2. Agora você pode emitir invocações usando a função invoke. Por exemplo, para buscar dados de uma função, você usaria o seguinte código:

Não conseguiu achar esse arquivo? Tente este

import { invoke } from "../runtime.ts";
import { useCallback } from "preact/hooks";

export default function MyIsland() {

  const fetchData = useCallback(() => {
    const data = await invoke["deco-sites/minha-loja"].loaders.myLoader({/* your function input props */});
  }, [])

  return <div>
    {...}
    <button onClick={fetchData}>Load</button>
  </div>
}

Aqui, a função invoke recebe um objeto com uma propriedade key que especifica o caminho para sua função e uma propriedade props que contém suas props de entrada da função. Quando você chama invoke, o live.ts irá invocar sua função como faz para renderizar seções e retorná-lo para você como um objeto JavaScript. É possível também chamar funções definidas em um App instalado no projeto. Por exemplo,

const dataAppVtex = await invoke.vtex.loaders.vtexLoader({
  /* your function input props */
});

Você também pode agrupar solicitações passando um objeto com várias chaves, cada uma representando uma invocação desejada. Por exemplo:

const { data1, data2 } = await invoke({
  data1: invoke.path1({/* your function input props */}),
  data2: invoke.path2({/* your function input props */}),
});

Com esses passos, agora você pode começar a usar a Invocação de funções client-side em sua aplicação Live.ts, happy coding!

Was this page helpful?
Can't find what you're looking for? Spot an error in the documentation? Get in touch with us on our Community Forum