O diretório components
O diretório components
contém seus componentes Vue.js. Os componentes são os que compõe as diferentes partes da sua página e podem ser reutilizados e importados dentro das suas páginas, dos esquemas e até dentro de outros componentes.
Requisição de dados
Para acessar dados assíncronos a partir de uma API dentro dos seus componentes você pode usar o método fetch()
do Nuxt.
Ao verificar o $fetchState.pending
, nós podemos exibir uma mensagem quando os dados estiverem esperando para serem carregados. Nós podemos também consultar o $fetchState.error
e exibir uma mensagem de erro se houver um erro na requisição dos dados. Sempre que estivermos usando o método fetch()
, nós devemos declarar as propriedades apropriadas dentro do método data()
. Os dados que vierem da requisição podem então ser atribuídos à estas propriedades.
<template>
<div>
<p v-if="$fetchState.pending">Loading....</p>
<p v-else-if="$fetchState.error">Error while fetching mountains</p>
<ul v-else>
<li v-for="(mountain, index) in mountains" :key="index">
{{ mountain.title }}
</li>
</ul>
</div>
</template>
<script>
export default {
data() {
return {
mountains: []
}
},
async fetch() {
this.mountains = await fetch(
'https://api.nuxtjs.dev/mountains'
).then(res => res.json())
}
}
</script>
Descoberta de componentes
data:image/s3,"s3://crabby-images/5cf9d/5cf9dcf5efa343d7eeee85d5dc3fb9eb51f3abc2" alt=""
A partir da versão v2.13
, o Nuxt pode importar automaticamente os componentes que você usar. Para ativar esta funcionalidade, defina components: true
dentro da sua configuração:
export default {
components: true
}
Qualquer componente dentro do diretório ~/components
podem então ser usados em todas as suas páginas, esquemas (e outros componentes) sem a necessidade de explicitamente importar eles.
| components/
--| TheHeader.vue
--| TheFooter.vue
<template>
<div>
<TheHeader />
<Nuxt />
<TheFooter />
</div>
</template>
Importação dinâmica
Para importar dinamicamente um componente, também conhecido como carregamento preguiçoso de um componente, tudo o que você precisa fazer é adicionar o prefixo Lazy
dentro dos seus modelos.
<template>
<div>
<TheHeader />
<Nuxt />
<LazyTheFooter />
</div>
</template>
Ao usar o prefixo lazy você pode também dinamicamente importar um componente quando um evento for acionado.
<template>
<div>
<h1>Mountains</h1>
<LazyMountainsList v-if="show" />
<button v-if="!show" @click="show = true">Show List</button>
</div>
</template>
<script>
export default {
data() {
return {
show: false
}
}
}
</script>
Diretórios aninhados
Se você tiver componentes dentro de diretórios aninhados tais como:
components/
base/
foo/
CustomButton.vue
O nome do componente será baseado no seu próprio caminho do diretório e nome de ficheiro. Portanto, o componente será:
<BaseFooCustomButton />
Se nós quisermos usar ele como <CustomButton />
enquanto mantém a estrutura do diretório, nós podemos adicionar o diretório de CustomButton.vue
dentro de nuxt.config.js
.
components: {
dirs: [
'~/components',
'~/components/base/foo'
]
}
E agora podemos usar o <CustomButton />
ao invés de <BaseFooCustomButton />
.
<CustomButton />
data:image/s3,"s3://crabby-images/02809/02809d5d0b947a227e8fb0ee22500128996ad2f3" alt="Sébastien Chopin"
data:image/s3,"s3://crabby-images/71bb0/71bb01a36c1cb0620f54e67240f5876951098a24" alt="川音리오"
data:image/s3,"s3://crabby-images/35191/351913147edaf5694e9cce82db331d6d0bce84a1" alt="Maciek Palmowski"
data:image/s3,"s3://crabby-images/dbdf4/dbdf4dee6905ee18c15debba1ef892aeeb284fd4" alt="Nestor Vera"
data:image/s3,"s3://crabby-images/cadc3/cadc35f5b8783a7c4ac84cfe5b457f2bdd316715" alt="Daniel Roe"
data:image/s3,"s3://crabby-images/6a8f3/6a8f359616ed7849eeb5e48ceb2de61b74acfb80" alt="Yue Yang"
data:image/s3,"s3://crabby-images/828cd/828cd3cf138ef6f9810d228c784673537f90310f" alt="Jeronimas"
data:image/s3,"s3://crabby-images/72ba7/72ba708780faac0c2580d395c18c381f5ade833d" alt="Clément Ollivier"
data:image/s3,"s3://crabby-images/21625/21625c0b7f7328109442dde704ce6905da12cccb" alt="Alexander Lichter"
data:image/s3,"s3://crabby-images/edded/eddedf743f60c91cda0425e8c9268a11a5b0a9c2" alt="N3-rd"
data:image/s3,"s3://crabby-images/9b959/9b959c19129bd9b6ea9c2d8f0861525d629ee703" alt="Adrien Zaganelli"
data:image/s3,"s3://crabby-images/b064d/b064d1b05f71c8e40ae8c73d00d280082a0af6c4" alt="Mag"
data:image/s3,"s3://crabby-images/9ef64/9ef64002c9fcfee1543348cec986fe61f9c8d1b0" alt="Stefan Huber"
data:image/s3,"s3://crabby-images/b80b0/b80b0f09b517fc7027beeb90916a1978ce80cc3b" alt="Olga Bulat"
data:image/s3,"s3://crabby-images/04bbb/04bbb30fa9d68e2ef9bcc3576e1b31cec2343e83" alt="Paiva"
data:image/s3,"s3://crabby-images/48abc/48abce3ff5e8b7e110dcb869a3fc40bb113514f8" alt="Florian Reuschel"
data:image/s3,"s3://crabby-images/f9a02/f9a02821c70d3208cc25ee7058e819d3b43dee3f" alt="Rishi Raj Jain"
data:image/s3,"s3://crabby-images/2ebd3/2ebd3b257babfbf79351850f5be8a6dc5ed24150" alt="Savas Vedova"
data:image/s3,"s3://crabby-images/be20d/be20dc4e8f15f02300837b8cd217d7510a1a2611" alt="Steven Soekha"
data:image/s3,"s3://crabby-images/ed48e/ed48ea75ec3ce10a4df2074324d513ee2e222766" alt="Vinícius Alves"
data:image/s3,"s3://crabby-images/c4db3/c4db3710e0068cd11e4c22c5f815e4cc13bcec0f" alt="Kareem Dabbeet"
data:image/s3,"s3://crabby-images/acd12/acd1228b7a2f9949156b917724b1630b1a22da43" alt="Valentín Costa"
data:image/s3,"s3://crabby-images/026cf/026cf7e2f227c326a718701b3c406fdda4af2c73" alt="Ryan Skinner"
data:image/s3,"s3://crabby-images/d3beb/d3beb848f64861056e4fca1079982e1dfdb6b31d" alt="Alex Hirzel"
data:image/s3,"s3://crabby-images/28573/2857361901038f9ec4a007b63f7855d5f8d2660e" alt="Ajeet Chaulagain"
data:image/s3,"s3://crabby-images/a1a0a/a1a0ab0c68dde52a841f5e562e9f3f07c686d21f" alt="René Eschke"
data:image/s3,"s3://crabby-images/62df7/62df7c16a1d16da305a4b436384dfe1d546fdf2f" alt="Nico Devs"
data:image/s3,"s3://crabby-images/c9799/c9799702351b0674215eb6d14413a0b069071bf1" alt="Muhammad Bin Shehzad"
data:image/s3,"s3://crabby-images/0353f/0353f3ff522e0e15e462c374652b3c5c29260eaa" alt="Nazaré da Piedade"
data:image/s3,"s3://crabby-images/129f5/129f5c56dfc4c3c0fa7b4c04074f198895b021fa" alt="Naoki Hamada"
data:image/s3,"s3://crabby-images/ae776/ae776e23b887653c0844d7d79c9a1cacae4d28f7" alt="Tom"
data:image/s3,"s3://crabby-images/b614e/b614e0774f76c28b67dd90201995ff26095e3164" alt="Yann Aufray"
data:image/s3,"s3://crabby-images/0bad3/0bad369422d38f4a92e4b4caf9b3a22be9c0b0ed" alt="Anthony Chu"
data:image/s3,"s3://crabby-images/938c1/938c1776876e1ea0bbe7deb5b37a3e155ee52b38" alt="Nuzhat Minhaz"
data:image/s3,"s3://crabby-images/22f92/22f92ce16cb1ccd2886bde50d3800fc3c0ff85a5" alt="Lucas Portet"
data:image/s3,"s3://crabby-images/f0b4f/f0b4fcecbd0c6422b39fad46fcb09df1486f184d" alt="Richard Schloss"
data:image/s3,"s3://crabby-images/a0d75/a0d751382672c257f5136502466935eb00c49240" alt="Bobby"
data:image/s3,"s3://crabby-images/d598c/d598cbd186210d2d1bceefaa836e0b22958fa3a8" alt="bpy"
data:image/s3,"s3://crabby-images/8d268/8d2681f75069deb9c53fedacd50cb27975559c54" alt="Antony Konstantinidis"
data:image/s3,"s3://crabby-images/19763/19763a4366672f0cab65243648c23a4a30e45fea" alt="Hibariya"
data:image/s3,"s3://crabby-images/abf77/abf77e59fe7fb6b0c0aca56e424b156257c92b92" alt="Jose Seabra"
data:image/s3,"s3://crabby-images/40b76/40b76230dd330f109ec41565a452668669fcac57" alt="Eze"
data:image/s3,"s3://crabby-images/aa692/aa69228111d63538af29bff0f7fa9ad904915ff0" alt="Florian Lefebvre"
data:image/s3,"s3://crabby-images/3c283/3c283fb13f938080081744e8e31ed4e9217ac1d9" alt="Lucas Recoaro"
data:image/s3,"s3://crabby-images/f03e6/f03e6b05e850fd760536e66b5bd48b4a3d4f852e" alt="Julien SEIXAS"
data:image/s3,"s3://crabby-images/bac76/bac76855f9d56bd458aefef6531edb27059fcd79" alt="Sylvain Marroufin"
data:image/s3,"s3://crabby-images/c60fb/c60fb5d72bd72124a0d56afeb7cb66e50c1b2b42" alt="Spencer Cooley"
data:image/s3,"s3://crabby-images/e2eec/e2eec326b133991228779ce960b4eb0c087a46b5" alt="Piotr Zatorski"
data:image/s3,"s3://crabby-images/30f3e/30f3e13a7a2aeb6e842999c39758aa8768537d75" alt="Vladimir Semyonov"
data:image/s3,"s3://crabby-images/d3162/d316201b66649537eaca361ed38ec0d99d686a0d" alt="Harry Allen"
data:image/s3,"s3://crabby-images/89967/89967c5526f979b97e527e5f56b5fe691324e2af" alt="kazuya kawaguchi"