Função Gatilho de Obtenção de Dados
A função gatilho fetch serve para buscar dados duma maneira assíncrona. É chamada no lado do servidor quando ao desenhar a rota, e no lado do cliente ao navegar.
Nuxt >= 2.12
A Nuxt v2.12 introduz uma nova função gatilho chamada fetch que podemos usar em qualquer um dos nossos componentes .vue, Usamos a fetch sempre que precisarmos de obter dados assíncronos. A fetch é chamada no lado do servidor ao desenhar a rota, e no lado do cliente ao navegar.
Expõe a $fetchState ao nível do componente:
- 
$fetchState.pending:Boolean, permite-nos mostrar um marcador de posição quando afetchfor chamada no lado do cliente. - 
$fetchState.error:nullouError, permite-nos mostrar uma mensagem de erro. - 
$fetchState.timestamp:Integer, é um marcador de data e hora da última busca de dados, útil para armazenamento transitório com okeep-alive. 
Se quisermos chamar a função gatilho fetch do nosso modelo de marcação de hipertexto, usamos:
<button @click="$fetch">Refresh</button>
 ou método de componente:
// dos métodos dos componentes na secção de programação.
export default {
  methods: {
    refresh() {
      this.$fetch()
    }
  }
}
 Podemos acessar o contexto  da Nuxt dentro da função gatilho fetch usando this.$nuxt.context.
Opções
- 
fetchOnServer:BooleanouFunction(predefinida como:true), chamafetchquando a página é desenhada pelo servidor. - 
fetchKey:StringouFunction(a predefinição é o identificador do âmbito do componente ou o nome do componente), uma chave (ou uma função produz uma chave única) que identifica o resultado da pesquisa deste componente (disponível na Nuxt 2.15+) Mais informações disponíveis no pedido de atualização do repositório original . - 
fetchDelay:Integer(predefinida como:200), define o tempo mínimo de execução em milissegundos (para evitar intermitências rápidas). 
Quando a fetchOnServer é false ou retorna false, fetch será chamada apenas no lado do cliente e $fetchState.pending retornará true quando o componente for desenhado no servidor:
<script>
  export default {
    data() {
      return {
        posts: []
      }
    },
    async fetch() {
      this.posts = await this.$http.$get('https://api.nuxtjs.dev/posts')
    },
    fetchOnServer: false,
    // vários componentes podem retornar a mesma `fetchKey` e
    // a Nuxt rastreará ambos separadamente
    fetchKey: 'site-sidebar',
    // Em alternativa, para um maior controlo,
    // pode ser passada uma função com acesso à instância do componente.
    // Será chamada na `created` e não deve depender de dados obtidos.
    fetchKey(getCounter) {
      // `getCounter` é um método que pode ser chamada para
      // obter o número seguinte numa sequência
      // como parte da geração duma `fetchKey` única.
      return this.someOtherData + getCounter('sidebar')
    }
  }
</script>
 fetch, consultar o capítulo de Obtenção de Dados  no livro de Funcionalidades.
 
        Sébastien Chopin
       
 
        Nazaré da Piedade
       
 
        Nobu
       
 
        川音리오
       
 
        Maciek Palmowski
       
 
        Nestor Vera
       
 
        Daniel Roe
       
 
        Yue Yang
       
 
        Jeronimas
       
 
        Alessandro Carrano
       
 
        Clément Ollivier
       
 
        Alexander Lichter
       
 
        N3-rd
       
 
        Adrien Zaganelli
       
 
        Mag
       
 
        Stefan Huber
       
 
        Olga Bulat
       
 
        Paiva
       
 
        Florian Reuschel
       
 
        Savas Vedova
       
 
        Steven
       
 
        Vinícius Alves
       
 
        Kareem Dabbeet
       
 
        Valentín Costa
       
 
        Ryan Skinner
       
 
        Alex Hirzel
       
 
        Ajeet Chaulagain
       
 
        René Eschke
       
 
        Nico Devs
       
 
        Muhammad
       
 
        Naoki Hamada
       
 
        Tom
       
 
        Yann Aufray
       
 
        Anthony Chu
       
 
        Nuzhat Minhaz
       
 
        Lucas Portet
       
 
        Richard Schloss
       
 
        Bobby
       
 
        bpy
       
 
        Antony Konstantinidis
       
 
        Hibariya
       
 
        Jose Seabra
       
 
        Eze
       
 
        Florian Lefebvre
       
 
        Lucas Recoaro
       
 
        Julien SEIXAS