Global config

A Nuxt application is configured through the nuxt.config.ts file. In this file, we can setup core features of nuxt, enable modules, configure them, extend from other layers, and more.

Each layer has a nuxt.config.ts file that is used to configure the layer itself. Layers can also have a app.config.ts file that is used to manage the layer's default app configuration. In that case, you should also find a nuxt.schema.ts file that is used to define the layer's configuration schema.

nuxt.config.js

This is an overview of the nuxt configuration file. It's used to change the way nuxt works (disable server-side rendering, change the build directory, etc, apply cache rules to specific routes, ...)

.app/nuxt.config.js

Runtime config

Everything defined in the .app/nuxt.config.ts file is not exposed in either the client or the server. To expose a variable to the client, you need to use the runtimeConfig property. This property is used to expose variables to the client, and to the server.

.app/nuxt.config.js

The runtime config can then be accessed in the server using the useRuntimeConfig nuxt composable:

.app/server/api/hello.ts

And in the client using same composable, note that you only have access to the public variables:

.app/components/MyComponent.vue

Environment variables

When using the runtimeConfig property, you can use environment variables to define their value. This is useful when you want to use different values for different environments.

Like seen in the previous example, you can define the NUXT_SECRET_KEY value using an environment variable.

During development, or at build time, you can use .env files to define environment variables. These files are located at the root of your project and are named .env and .env.local. Note that when running the production build, no .env file is used.


Useful resources:

In addition to the nuxt configuration, another file is used to configure the app itself. This file is named app.config.ts and is used to configure the app layout, theme, and more.

app.config.ts

.app/app.config.js

App configuration can then be accessed in components using the useAppConfig nuxt composable. We use this internally to configure the layout, the theme, and other features, but nothing stops you from using it to configure your own components.

.app/components/MyComponent.vue

Useful resources: