Nuxt 3 がリリースされました! https://nuxt.com/v3 で詳細について見れます。

翻訳されたページ このページのコンテンツは古い可能性があります。

Nuxt 設定ファイル

Nuxt ではデフォルトの設定でほとんどのユースケースをカバーしています。nuxt.config.js を使ってこの設定を上書きすることができます。


nuxt.config.js

alias

このオプションで JavaScript や CSS で利用可能なエイリアスを定義できます。

nuxt.config.js
import { resolve } from 'path'

export default {
  alias: {
    'style': resolve(__dirname, './assets/style')
  }
}

build

このオプションで、loadersfilenameswebpack の設定、transpilation を含む build ステップにおけるさまざまな設定を行うことができます。

nuxt.config.js
export default {
  build: {
    /*
     ** ここで webpack の設定を拡張することができます。
     */
    extend(config, ctx) {}
  }
}

css

このオプションで、グローバルに(すべてのページで)利用したい CSS ファイル/モジュール/ライブラリを指定できます。

nuxt.config.js
export default {
  css: ['~/assets/css/main.css', '~/assets/css/animations.scss']
}

nuxt の設定ファイルで、css プロパティの配列に記述する CSS、SCSS、Postcss、Less、Stylus などのファイルの拡張子は省略することができます。

nuxt.config.js
export default {
  css: ['~/assets/css/main', '~/assets/css/animations']
}

拡張子を省略することで、例えば css ファイルを使用していて sass を使うように変更した場合でも、ファイル名が同じままであれば新しい拡張子が使用されるので、nuxt.config を更新する必要はありません。

dev

このオプションで、Nuxt の development または production モードを定義できます。(Nuxt をプログラム上で使う際に重要です)

nuxt.config.js
export default {
  dev: process.env.NODE_ENV !== 'production'
}

env

このオプションを使うと、NODE_ENV=stagingVERSION=1.2.3 のように、ビルド時(ランタイムではなく)に必要な環境変数を定義することができます。ただし、ランタイム環境変数の場合は runtimeConfig が必要です。

nuxt.config.js
export default {
  env: {
    baseURL: process.env.BASE_URL
  }
}

runtimeConfig

ランタイム設定にはより良いセキュリティと高速な開発のため dotenv サポートが組み込まれています。ランタイム設定は Nuxt ペイロードに追加されるので、開発中、サーバーサイドレンダリング、またはクライアントサイドのみのアプリケーションで作業する際に、ランタイム設定を更新するためにリビルドする必要はありません。(静的サイトでは変更を確認するためにサイトをリビルドする必要があります)

.env サポート

もしプロジェクトのルートディレクトリに .env ファイルがあるなら、自動的に process.env にロードされ、nuxt.config / serverMiddleware またはそれらがインポートする別のファイル内からアクセスできます。

--dotenv <file> を使用してパスをカスタマイズすることができ、また --dotenv false を使用して完全に無効にすることができます。例えば本番、ステージング、開発環境で違う .env ファイルを指定することができます。

publicRuntimeConfig

  • フロントエンドに公開されるのでパブリックな env 変数はすべて保持しなければなりません。例として公開 URL への参照を含めることができます。
  • サーバーとクライアントの両方で $config を使って利用できます。
nuxt.config.js
export default {
  publicRuntimeConfig: {
    baseURL: process.env.BASE_URL || 'https://nuxtjs.org'
  }
}

privateRuntimeConfig

  • プライベートでフロントエンドでは公開されてはいけないすべての env 変数を保持しなければなりません。例として API のシークレットトークンへの参照を含めることができます。
  • サーバーのみで同じく $config を使って利用できます。(publicRuntimeConfig を上書きします)
nuxt.config.js
export default {
  privateRuntimeConfig: {
    apiSecret: process.env.API_SECRET
  }
}

設定値を使用する:

ページ、ストア、コンポーネント、プラグインのコンテキストを使って、this.$configcontext.$config を使用することで、どこからでもこれらの値にアクセスすることができます。

pages/index.vue
<script>
  asyncData ({ $config: { baseURL } }) {
    const posts = await fetch(`${baseURL}/posts`)
      .then(res => res.json())
  }
</script>

テンプレートの中では、$config.* を使って直接ランタイム設定にアクセスできます。

pages/index.vue
<template>
  <p>Our Url is: {{ $config.baseURL}}</p>
</template>
サーバーのみのコンテキスト以外で $config を使用した場合(例えば fetchasyncData、 あるいはテンプレート内で直接 $config を使用した場合など)、プライベートな設定が公開される可能性があります。

generate

このオプションで、Nuxt によって HTML ファイルに変換されるアプリケーション内のすべての動的ルートのパラメータを設定することができます。

nuxt.config.js
export default {
  generate: {
    dir: 'gh_pages', // dist/ の代わりに gh_pages/ を設定する
    subFolders: false // HTML ファイルがルートパスに従って生成されます
  }
}
nuxt.config.js
export default {
    head: {
    title: 'my title',
    meta: [
      { charset: 'utf-8' },
            .....
        ]
    }
}

このオプションで、アプリケーションのデフォルトのメタタグを全て指定できます。

loading

このオプションで、Nuxt のデフォルトのローディングコンポーネントをカスタマイズできます。

nuxt.config.js
export default {
  loading: {
    color: '#fff'
  }
}

modules

このオプションで、プロジェクトに Nuxt モジュールを追加できます。

nuxt.config.js
export default {
  modules: ['@nuxtjs/axios']
}

modulesDir

modulesDir プロパティは、モジュールディレクトリの設定でパス解決のために使用します。例えば Webpack の resolveLoading、 nodeExternals や postcss です。設定パスは options.rootDir (デフォルト: process.cwd())からの相対パスになります。

nuxt.config.js
export default {
  modulesDir: ['../../node_modules']
}

プロジェクトが Yarn ワークスペーススタイルのモノリポジトリで構成されている場合はこのフィールドが必要になるかもしれません。

plugins

このオプションで、ルートの Vue.js アプリケーションをインスタンス化する前に実行したい JavaScript plugin を指定できます。

nuxt.config.js
export default {
  plugins: ['~/plugins/url-helpers.js']
}

router

`router オプションで、Nuxt のデフォルトの Vue Router 設定を上書きできます。

nuxt.config.js
export default {
  router: {
    linkExactActiveClass: 'text-primary'
  }
}

server

このオプションで、Nuxt アプリケーションのサーバーインスタンスにおける接続変数を設定できます。

nuxt.config.js
import path from 'path'
import fs from 'fs'

export default {
  server: {
    https: {
      key: fs.readFileSync(path.resolve(__dirname, 'server.key')),
      cert: fs.readFileSync(path.resolve(__dirname, 'server.crt'))
    }
  }
}

srcDir

このオプションで、Nuxt アプリケーションのソースディレクトリを指定できます。

nuxt.config.js
export default {
  srcDir: 'client/'
}

client ディレクトリにある Nuxt アプリケーションのプロジェクト構造の例です。

**-| app/
---| node_modules/
---| nuxt.config.js
---| package.json
---| client/
------| assets/
------| components/
------| layouts/
------| middleware/
------| pages/
------| plugins/
------| static/
------| store/**

dir

このオプションで、Nuxt のディレクトリのカスタムネームを指定できます。

nuxt.config.js
export default {
  dir: {
    pages: 'views' // Nuxt は pages/ フォルダの代わりに views/ を探します。
  }
}

pageTransition

このオプションで、ページトランジションのデフォルトプロパティを指定できます。

nuxt.config.js
export default {
  pageTransition: 'page'
}

その他の設定ファイル

nuxt.config.js の他にもプロジェクトのルートに .eslintrc prettier.config.json .gitignore などの設定ファイルがあるかもしれません。これらは linter やコードフォーマッタ、git リポジトリなどの他のツールを設定するために使われ、nuxt.config.js から切り離されています。

.gitignore

.gitignore ファイルに以下の項目を追加して、バージョン管理から無視かつ追加されないようにする必要があります。node_modules フォルダはインストールしたモジュールがすべて入っているフォルダです。nuxt フォルダは、dev コマンドや build コマンドを実行したときに作成されるフォルダです。dist フォルダは generate コマンドの実行時に作成されるフォルダです。

.gitignore
node_modules .nuxt dist

この次は?