コンテキストとヘルパー
コンテキストは、アプリケーションへの現在のリクエスト (request) に関する追加の情報とオプション情報を提供します。
context
オブジェクトは、asyncData 、plugins 、middleware そして nuxtServerInit といった特定の Nuxt 関数で利用できます。これは、アプリケーションへの現在のリクエストに関する追加の情報とオプション情報を提供します。
何よりもまず、コンテキストは Nuxt アプリケーションの他の部分(例えば Vuex ストアや基盤となる connect
インスタンス)へのアクセスを提供するために使用されます。そのため、サーバーサイドと store
で使用可能なコンテキストの req
オブジェクトと res
オブジェクトは常に使用可能です。しかし、時間が経つにつれコンテキストは他の多くの役立つ変数やショートカットで拡張されました。今では development
モードの HMR (ホットモジュールリロード、またはリプレイスメント) 機能、現在の route
、ページの params
、そして query
にアクセスできるほか、コンテキストを介して環境変数にアクセスするオプションもあります。さらに、モジュール関数とヘルパーは、クライアントサイドとサーバーサイドの両方で使用できるようにコンテキストを通じて公開できます。
デフォルトで存在するすべてのコンテキストキー
function (context) { // asyncData, nuxtServerInit, ...
// 常に利用可能
const {
app,
store,
route,
params,
query,
env,
isDev,
isHMR,
redirect,
error,
$config
} = context
// サーバーサイドでのみ利用可能
if (process.server) {
const { req, res, beforeNuxtRender } = context
}
// クライアントサイドでのみ利用可能
if (process.client) {
const { from, nuxtState } = context
}
}
context
オブジェクトや nuxt.config.js
の build.extend
関数で利用可能な context
オブジェクトと混同しないでください。これらは互いに関連していません!他のコンテキストキーについての詳細はコンテキストのドキュメント を参照してください。
API クエリ用にページパラメータを使う
コンテキストは context.params
を介してルートのとりうる動的パラメータを直接公開します。次の例では、URL の一部として動的ページパラメータを使用して、nuxt/http
モジュールを介して API を呼び出します。nuxt/http モジュールは、context.app オブジェクトを介して利用できる独自の関数を公開できます。
また、潜在的なエラーを処理するために API の呼び出しを try/catch
構文でラップします。context.error
関数を使用すると、Nuxt のエラーページを直接表示して発生したエラーを渡すことができます。
export default {
async asyncData(context) {
const id = context.params.id
try {
// nuxtjs/http モジュールをここで使い context.app を介して公開します
const post = await context.app.$http.$get(
`https://api.nuxtjs.dev/posts/${id}`
)
return { post }
} catch (e) {
context.error(e) // スローしたエラーと一緒に nuxt エラーページを表示します
}
}
}
ES6 を使用すると、この構文を使用してコンテキストオブジェクトを分解できます。アクセスしたいオブジェクトを渡すと、コンテキストという単語を使用せずにコードでそれらを使用できます。
export default {
async asyncData({ params, $http, error }) {
const id = params.id
try {
// nuxtjs/http モジュールをここで使い context.app を介して公開します
const post = await $http.$get(`https://api.nuxtjs.dev/posts/${id}`)
return { post }
} catch (e) {
error(e) // スローしたエラーと一緒に nuxt エラーページを表示します
}
}
}
代わりにクエリパラメータを使いたい場合は、context.query.id を使ってください。
ユーザをリダイレクトさせストアへアクセスする
Vuex store ストアへのアクセス(store
ディレクトリを介して設定した場合)もコンテキストを介して可能です。これは、Vue コンポーネントで this.$store
として扱うことができる store
オブジェクトを提供します。さらに、コンテキストを介して公開されたヘルパーである redirect
メソッドを使用して authenticated
状態が falsy な場合にユーザーをリダイレクトします。
export default {
middleware({ store, redirect }) {
// 分解した (destructuring) オブジェクトからキーを取得する
const isAuthenticated = store.state.authenticated
if (!isAuthenticated) {
return redirect('/login')
}
}
}
ヘルパー
コンテキスト内のショートカットに加えて、Nuxt アプリケーションには他の小さなヘルパーもあります。
$nuxt
: Nuxt ヘルパー
$nuxt
はユーザーエクスペリエンスを向上させ、状況によってはエスケープハッチになるように設計されたヘルパーです。Vue コンポーネントでは this.$nuxt
を介してアクセスでき、それ以外の場合はクライアント側で window.$nuxt
を介してアクセスできます。
コネクションチェッカー
$nuxt
ヘルパーはユーザーのインターネット接続があるかどうかをすばやく確認する方法を提供します。ブール値の isOffline
と isOnline
を公開します。これらを使用して例えば、ユーザーがオフラインになるとすぐにメッセージを表示できます。(以下の例)
<template>
<div>
<div v-if="$nuxt.isOffline">You are offline</div>
<Nuxt />
</div>
</template>
ルートインスタンスへアクセスする
DX/UX (デベロッパーエクスペリエンス / ユーザーエクスペリエンス) 機能を提供することに加え、$nuxt
ヘルパーは他のすべてのコンポーネントからアプリケーションのルートインスタンスへのショートカットも提供します。しかし、それだけではありません。Vue コンポーネントの外部から $axios
などのモジュールメソッドにアクセスするためのエスケープハッチとして使用できる window.$nuxt
を介して $nuxt
ヘルパーにアクセスすることもできます。賢明に使う必要があり最後の手段としてしてください。
ページデータのリフレッシュ
ユーザーの現在のページを更新したい場合、サーバーに再度アクセスして少なくとも Nuxt アプリケーション全体を再初期化する可能性があるのでページを完全にリロードさせたくないでしょう。リロードの代わりに asyncData
または fetch
によって提供されるデータのみを更新したい場合がよくあります。
これは this.$nuxt.refresh()
を使って行えます!
<template>
<div>
<div>{{ content }}</div>
<button @click="refresh">Refresh</button>
</div>
</template>
<script>
export default {
asyncData() {
return { content: 'Created at: ' + new Date() }
},
methods: {
refresh() {
this.$nuxt.refresh()
}
}
}
</script>
ローディングバーの制御
$nuxt
を使うと、Nuxt のローディングバーを this.$nuxt.$loading
を介してプログラムで制御できます。
export default {
mounted() {
this.$nextTick(() => {
this.$nuxt.$loading.start()
setTimeout(() => this.$nuxt.$loading.finish(), 500)
})
}
}
詳細についてはローディング機能のドキュメント を参照してください。
onNuxtReady ヘルパー
Nuxt アプリケーションがロードされて準備ができた 後 、いくつかのスクリプトを実行する場合は、 window.onNuxtReady
関数を使用できます。これはサイトのインタラクティブ化にかかる時間を増やすことなく、クライアントサイドで関数を実行したい場合に便利です。
window.onNuxtReady(() => {
console.log('Nuxt is ready and mounted')
})
プロセスヘルパー
Nuxt はグローバルな process
オブジェクトに 3 つのブール値 (client
、 server
および static
) を挿入します。これはアプリケーションがサーバーでレンダリングされたか、完全にクライアントでレンダリングされたかを判断し、静的サイトの生成を確認するのに便利です。これらのヘルパーはアプリケーション全体で利用でき、asyncData
ユーザーランドコードで一般的に使用されています。
<template>
<h1>I am rendered on the {{ renderedOn }} side</h1>
</template>
<script>
export default {
asyncData() {
return { renderedOn: process.client ? 'client' : 'server' }
}
}
</script>
この例ではサーバーサイドレンダリングを使用し、ユーザーが直接ページにアクセスすると renderedOn
は 'server'
と評価されます。ユーザーがアプリケーションの別の部分からページに遷移する場合(例えば <NuxtLink>
をクリックする場合)クライアントに評価されます。
data:image/s3,"s3://crabby-images/c079f/c079f408bc783e75be10a58380dcd8f75fc6fe30" alt="Sébastien Chopin"
data:image/s3,"s3://crabby-images/a36f1/a36f155e74808db2757a1b6265083d6a6d4fc94c" alt="Nazaré da Piedade"
data:image/s3,"s3://crabby-images/96e50/96e5023b65c2d33f36fe7c3eac0a0c96b238658e" alt="Nobu"
data:image/s3,"s3://crabby-images/f29a0/f29a0d620d87519a52cfd0ae8e69128a162a7b67" alt="川音리오"
data:image/s3,"s3://crabby-images/2677d/2677de88513b8010c060962c34aeb67dac770a18" alt="Maciek Palmowski"
data:image/s3,"s3://crabby-images/404a5/404a58aea4ef3c54629ba26fc32a51d6e2a18a5f" alt="Nestor Vera"
data:image/s3,"s3://crabby-images/98a40/98a40243e9a287aa704ef3dc22e5fc28e59b7574" alt="Daniel Roe"
data:image/s3,"s3://crabby-images/b7385/b7385c01953ba5d76898a41fb5b24feb98bc4bb2" alt="Yue Yang"
data:image/s3,"s3://crabby-images/2a3d1/2a3d1e419f61998b33f62e14cf9b5a4783aa7794" alt="Jeronimas"
data:image/s3,"s3://crabby-images/b336a/b336a791a4de2d8cb75b955cb90eabf2879b83a5" alt="Clément Ollivier"
data:image/s3,"s3://crabby-images/37dca/37dcaf7d38f5846b7c5c9c391f5918a51ccd934c" alt="Alexander Lichter"
data:image/s3,"s3://crabby-images/a27d2/a27d2e6048cbb2955844e53dd5ec8a75e08ea2cd" alt="N3-rd"
data:image/s3,"s3://crabby-images/d6a94/d6a9457c88e2400fa917f2d9ae084e5b1a1cb517" alt="Adrien Zaganelli"
data:image/s3,"s3://crabby-images/e2529/e2529558cb857cbf0010c38a88b255deea628bdf" alt="Mag"
data:image/s3,"s3://crabby-images/5b539/5b5399cdda0f1d2b5b03e847623b619a64ac1d0f" alt="Stefan Huber"
data:image/s3,"s3://crabby-images/2b5ad/2b5ad589e7cc4f5c0babe7670eefddc43968146e" alt="Olga Bulat"
data:image/s3,"s3://crabby-images/c30e9/c30e9a86a4692d5c123c90220ddca7a458e17e35" alt="Paiva"
data:image/s3,"s3://crabby-images/5d4bf/5d4bff0bf543f1ad8ce5610ae03bb5c2901dc1df" alt="Florian Reuschel"
data:image/s3,"s3://crabby-images/b8800/b8800632d3225a51be4bed995e635716c72d6761" alt="Savas Vedova"
data:image/s3,"s3://crabby-images/3eb50/3eb5088ee9bebfb29c66604180d5f1786dcc288e" alt="HIJACK"
data:image/s3,"s3://crabby-images/ba3ff/ba3ffe962ceab2637a46936c4b3832823bb0f5e8" alt="Vinícius Alves"
data:image/s3,"s3://crabby-images/75fcf/75fcfe777c70ebb7577bde2a0c2e2f82512da323" alt="Kareem Dabbeet"
data:image/s3,"s3://crabby-images/da55d/da55d7a86e3c71ef5371bfcd5fbf9faaed6ddc51" alt="Valentín Costa"
data:image/s3,"s3://crabby-images/9d225/9d22581d38ab2acd1069230435358270c09a5128" alt="Ryan Skinner"
data:image/s3,"s3://crabby-images/c9d3b/c9d3b3b0b99544192e54a41ae709bd992c32794f" alt="Alex Hirzel"
data:image/s3,"s3://crabby-images/a66f5/a66f51077e5283065acdcf5249a88a6dcda457b7" alt="Ajeet Chaulagain"
data:image/s3,"s3://crabby-images/cc775/cc77528ad32d6df1c92dcd7819df9c709e7aae17" alt="René Eschke"
data:image/s3,"s3://crabby-images/4f930/4f9307ea6d868688a41bce88daa5e734dd7b4f30" alt="Nico Devs"
data:image/s3,"s3://crabby-images/642a4/642a45e9f53437a0dc0786dad3822b47542ab41e" alt="Muhammad"
data:image/s3,"s3://crabby-images/578b7/578b7a4826d9e9c79b10c0a440bf6023cac8634d" alt="Naoki Hamada"
data:image/s3,"s3://crabby-images/18000/18000ed7b913e1a5ef0c301cec202908424f2b36" alt="Tom"
data:image/s3,"s3://crabby-images/f2eaa/f2eaafbc890bdba93ddfc694d9ceb7a59bf21a4c" alt="Yann Aufray"
data:image/s3,"s3://crabby-images/28706/2870667dfa80efaff50559c179c068fbf01ef205" alt="Anthony Chu"
data:image/s3,"s3://crabby-images/18462/18462ffca9a6899eec5a54b7de6a45887d0729c8" alt="Nuzhat Minhaz"
data:image/s3,"s3://crabby-images/9f43b/9f43ba42692b50b513a0f9fee1d9c100d0c9f177" alt="Lucas Portet"
data:image/s3,"s3://crabby-images/87bb8/87bb8cdadf010bc5ead4801489bb088532a79443" alt="Richard Schloss"
data:image/s3,"s3://crabby-images/6bf20/6bf2065989faa4ad57a63c65a21c0d4918a0dd73" alt="Bobby"
data:image/s3,"s3://crabby-images/c5e5e/c5e5e61af957ba4bebf4242162f8db94d3da7ca1" alt="bpy"
data:image/s3,"s3://crabby-images/bbc3f/bbc3fdf0e5e37795f6a3a8267834e6b3b9cdb8ce" alt="Antony Konstantinidis"
data:image/s3,"s3://crabby-images/3ba7a/3ba7a27e05f9691d23fa8d0b28e16355254be5ec" alt="Hibariya"
data:image/s3,"s3://crabby-images/e12ba/e12ba2b49b19dd4dee0cab2dee520f022fc39436" alt="Jose Seabra"
data:image/s3,"s3://crabby-images/ab2b3/ab2b3791f0b93c3d266a07a7331e8c639c45b840" alt="Eze"
data:image/s3,"s3://crabby-images/fe12d/fe12d1c0b546b012067bd695ea18752e750c162f" alt="Florian Lefebvre"
data:image/s3,"s3://crabby-images/3f4be/3f4bee239f7004d6c28c9006fd5b9bb5ad3cae9e" alt="Lucas Recoaro"
data:image/s3,"s3://crabby-images/736af/736af6fee3723bd40ca1a4cea3f57ece7f182b15" alt="Julien SEIXAS"