プラグインディレクトリ
plugins
ディレクトリにはルート Vue.js アプリケーションがインスタンス化する前に実行する Javascript プラグインが含まれています。
これは Vue プラグインを追加し、関数や定数を導入する場所です。Vue.use()
を使用する必要がある時は都度 plugins/
ファイルを作成し、nuxt.config.js
の plugins にそのパスを追加する必要があります。
外部パッケージ
サーバーとクライアント両方に HTTP リクエストを行うためには、アプリケーションで外部パッケージ/モジュール(著名な例は axios です)を使用することをお勧めします。
はじめに、npm か Yarn を介してインストールします。
yarn add @nuxtjs/axios
npm install @nuxtjs/axios
例えば、アプリケーション全体の API 呼び出しから発生する可能性のあるエラーに対応するよう、axios インターセプターを設定できます。この例では、API から 500 ステータスエラーが発生した時、sorry というカスタムエラーページにユーザをリダイレクトします。
export default function ({ $axios, redirect }) {
$axios.onError(error => {
if (error.response.status === 500) {
redirect('/sorry')
}
})
}
最後になりますが、モジュールと新しく作成したプラグインをプロジェクト構成に追加します。
module.exports = {
modules: ['@nuxtjs/axios'],
plugins: ['~/plugins/axios.js']
}
そのあとページコンポーネントで直接使用できます:
<template>
<h1>{{ post.title }}</h1>
</template>
<script>
export default {
async asyncData ({ $axios, params }) {
const post = await $axios.$get(`https://api.nuxtjs.dev/posts/${params.id}`)
return { post }
}
}
</script>
モジュールのインストールなしで axios
を使うための他の方法は、<script>
タグで直接 axios
をインポートすることです。
<script>
import axios from 'axios'
export default {
async asyncData ({ params }) {
const { data: post } = await axios.get(`https://api.nuxtjs.dev/posts/${params.id}`)
return { post }
}
}
</script>
nuxt.config.js
の build
> transpile
オプションにパッケージを追加する必要があります。build: {
// ここでwebpack設定を拡張できます
transpile: ['npm-package-name'],
},
Vue プラグイン
v-tooltip などの Vue プラグインを使用してアプリケーションにツールチップを表示する場合、アプリを起動する前にプラグインを設定する必要があります。
はじめにインストールをする必要があります
yarn add v-tooltip
npm install v-tooltip
次にファイル plugins/vue-tooltip.js
を作成します
import Vue from 'vue'
import VTooltip from 'v-tooltip'
Vue.use(VTooltip)
plugins プロパティ
次に nuxt.config.js
の plugins
キー内にファイルパスを追加します。plugins プロパティを使用すると、簡単に Vue.js プラグインをメインアプリケーションに追加できます。plugins
プロパティで定義されているすべてのパスは、メインアプリケーションを初期化する前にインポートされます。
export default {
plugins: ['~/plugins/vue-tooltip.js']
}
ES6 プラグイン
プラグインが node_modules
にあり、ES6 モジュールをエクスポートする場合、transpile
ビルドオプションに追加する必要がある場合があります:
module.exports = {
build: {
transpile: ['vue-tooltip']
}
}
その他のビルドオプションについては、configuration build のドキュメントを参照してください。
クライアントまたはサーバーサイドのみ
一部のプラグインは SSR がサポートされていないため、ブラウザのみで機能する場合があります。
従来のプラグインに名前を付ける
プラグインがクライアント、もしくはサーバーサイドのみで実行されると想定される場合、.client.js
または .server.js
は、プラグインファイルの拡張子として適用できます。ファイルはそれぞれの(クライアントまたはサーバー)サイドのみに自動的に含まれます。
export default {
plugins: [
'~/plugins/foo.client.js', // クライアントサイドのみ
'~/plugins/bar.server.js', // サーバーサイドのみ
'~/plugins/baz.js' // クライアントサイドとサーバーサイド両方
]
}
オブジェクト構文
plugins
の mode
プロパティ('client'
または 'server'
)でオブジェクト構文を使用することもできます。
export default {
plugins: [
{ src: '~/plugins/both-sides.js' },
{ src: '~/plugins/client-only.js', mode: 'client' }, // クライアントサイドのみ
{ src: '~/plugins/server-only.js', mode: 'server' } // サーバーサイドのみ
]
}
$root
とコンテキストの挿入
ときどき、アプリケーション内で関数や値を利用できるようにしたい場合があります。これらの変数を Vue インスタンス(クライアントサイド)、コンテキスト(サーバーサイド)、さらには Vuex ストアに挿入できます。これらの関数の前に $
を付けるのが慣例です。
Nuxt はこれを簡単に行うための inject(key、value
メソッドを提供します。関数をエクスポートするとき、2 番目のパラメーターとして Inject が指定されます。$
は、キーの先頭に自動的に追加されます。
beforeCreate
フックと created
フックのみがクライアント、サーバーサイド両方から呼び出されることを把握しておくことが重要です。他のすべてのフックはクライアントサイドからのみ呼び出されます。export default ({ app }, inject) => {
// Vue、コンテキスト、そしてストアに $hello(msg)を挿入します。
inject('hello', msg => console.log(`Hello ${msg}!`))
}
export default {
plugins: ['~/plugins/hello.js']
}
$hello
サービスは、ページ、コンポーネント、プラグイン、ストアアクションの context
と this
にアクセスできるようになりました。
export default {
mounted() {
this.$hello('mounted')
// console.log 'Hello mounted!' が呼び出される
},
asyncData({ app, $hello }) {
$hello('asyncData')
// Nuxt <= 2.12 を使用する場合は 👇
app.$hello('asyncData')
}
}
export const state = () => ({
someValue: ''
})
export const actions = {
setSomeValueToWhatever({ commit }) {
this.$hello('store action')
const newValue = 'whatever'
commit('changeSomeValue', newValue)
}
}
Vue.use()
、Vue.component()
を使用しないでください、またグローバルに、Nuxt インジェクション専用のこの関数内に Vue を接続しないでください。サーバーサイドでメモリリークが発生します。extendPlugins プロパティ
プラグインを拡張したり、Nuxt によって作成されたプラグインの順序を変更したりすることができます。この関数は plugin オブジェクトの配列を受け入れ、プラグインオブジェクトの配列を返す必要があります。
プラグインの順序を変更する例:
export default {
extendPlugins(plugins) {
const pluginIndex = plugins.findIndex(
({ src }) => src === '~/plugins/shouldBeFirst.js'
)
const shouldBeFirstPlugin = plugins[pluginIndex]
plugins.splice(pluginIndex, 1)
plugins.unshift(shouldBeFirstPlugin)
return plugins
}
}
グローバルミックスイン
グローバルミックスインは Nuxt プラグインで簡単に追加できますが、正しく処理しないとトラブルやメモリリークが発生する可能性があります。アプリケーションにグローバルミックスインを追加するときは、常にフラグを使用して複数回登録しないようにする必要があります:
import Vue from "vue"
// 他の mixin と衝突しないように
// フラグの名前は必ずユニークなものにしてください。
if (!Vue.__my_mixin__) {
Vue.__my_mixin__ = true
Vue.mixin({ ... }) // ミックスインを設定する
}
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"