Installation
Learn how to install and configure Nuxt UI in your application.
Setup
- Install @nuxt/uidependency to your project:
pnpm add @nuxt/ui
- Add it to your modulessection in yournuxt.config:
export default defineNuxtConfig({
  modules: ['@nuxt/ui']
})
That's it! You can now use all the components and composables in your Nuxt app ✨
Modules
Nuxt UI will automatically install the @nuxtjs/tailwindcss, @nuxtjs/color-mode and nuxt-icon modules for you.
modules and dependencies if you've previously installed them.@nuxtjs/tailwindcss
This module is pre-configured and will automatically load the following plugins:
- @tailwindcss/forms
- @tailwindcss/typography
- @tailwindcss/aspect-ratio
- @tailwindcss/container-queries
- @headlessui/tailwindcss
Note that the @tailwindcss/aspect-ratio plugin disables the default aspect ratio utilities:
- aspect-auto
- aspect-square
- aspect-video
You can re-enable them by adding the following to your tailwind.config.ts:
import type { Config } from 'tailwindcss'
export default <Partial<Config>>{
  theme: {
    extend: {
      aspectRatio: {
        auto: 'auto',
        square: '1 / 1',
        video: '16 / 9'
      }
    }
  }
}
@nuxtjs/color-mode
This module is installed to provide dark mode support out of the box thanks to the Tailwind CSS dark mode class strategy.
nuxt-icon
This module is installed when using the dynamic prop on the Icon component or globally through the ui.icons.dynamic option in your app.config.ts.
TypeScript
This module is written in TypeScript and provides typings for all the components and composables. You can look at the source code to see all the available types.
You can use those types in your own components by importing them from #ui/types, for example when defining wrapper components:
<template>
  <UBreadcrumb :links="links">
    <template #icon="{ link }">
      <UIcon :name="link.icon" />
    </template>
  </UBreadcrumb>
</template>
<script setup lang="ts">
import type { BreadcrumbLink } from '#ui/types'
export interface Props {
  links: BreadcrumbLink[]
}
defineProps<Props>()
</script>
You don't have to use TypeScript yourself, but doing so will give you access to prop validation and autocomplete.
We've managed to provide dynamic typings on props such as color, size, variant, etc. based on your custom config. For example, you'll be suggested the custom color and the subtle variant when using the Button component with an app.config.ts as such:
export default defineAppConfig({
  ui: {
    button: {
      color: {
        custom: {
          subtle: '...'
        }
      }
    }
  }
})
IntelliSense
If you're using VSCode, you can install the Tailwind CSS IntelliSense extension to get autocompletion for the classes.
You can read more on how to set it up on the @nuxtjs/tailwindcss module documentation, but to summarize, you'll need to add the following to your .vscode/settings.json:
{
  "files.associations": {
      "*.css": "tailwindcss"
  },
  "editor.quickSuggestions": {
      "strings": true
  }
}
You can write your tailwind.config in TypeScript as such:
import type { Config } from 'tailwindcss'
export default <Partial<Config>> {
  content: [
    'docs/content/**/*.md'
  ]
}
If you do so, you'll need to add the following to your .vscode/settings.json:
{
  "tailwindCSS.experimental.configFile": "tailwind.config.ts"
}
Note, the extension won't work when writing classes in your app.config.ts by default.
Also, you might want IntelliSense on objects in your SFC by prefixing with /*ui*/.
To enable these two features, you can add the following to your .vscode/settings.json:
{
  "tailwindCSS.experimental.classRegex": [
    ["ui:\\s*{([^)]*)\\s*}", "[\"'`]([^\"'`]*).*?[\"'`]"],
    ["/\\*\\s?ui\\s?\\*/\\s*{([^;]*)}", ":\\s*[\"'`]([^\"'`]*).*?[\"'`]"]
  ]
}
An example SFC using IntelliSense (note the /*ui*/ prefix, also works with ref()):
<template>
  <UCard :ui="ui" />
</template>
<script setup lang="ts">
const ui = /* ui */ {
  background: 'bg-white dark:bg-slate-900'
}
</script>
You can also add the following to your .vscode/settings.json to enable IntelliSense when using the ui prop:
{
  "tailwindCSS.classAttributes": [
    "class",
    "className",
    "ngClass",
    "ui"
  ]
}
Options
| Key | Default | Description | 
|---|---|---|
| prefix | u | Define the prefix of the imported components. | 
| global | false | Expose components globally. | 
| icons | ['heroicons'] | Icon collections to load. | 
| safelistColors | ['primary'] | Force safelisting of colors to need be purged. | 
| disableGlobalStyles | false | Disable global CSS styles injected by the module. | 
Configure options in your nuxt.config.ts as such:
export default defineNuxtConfig({
  modules: ['@nuxt/ui'],
  ui: {
    global: true,
    icons: ['mdi', 'simple-icons']
  }
})
Edge
To use the latest updates pushed on the dev branch, you can use @nuxt/ui-edge.
Update your package.json to the following:
{
  "devDependencies": {
-   "@nuxt/ui": "^2.11.0"
+   "@nuxt/ui": "npm:@nuxt/ui-edge@latest"
  }
}
Then run pnpm install, yarn install or npm install.