Usage with NuxtJS
It is possible to implement FSD in a NuxtJS project, but conflicts arise due to the differences between NuxtJS project structure requirements and FSD principles:
- Initially, NuxtJS offers a project file structure without a srcfolder, i.e. in the root of the project.
- The file routing is in the pagesfolder, while in FSD this folder is reserved for the flat slice structure.
Adding an alias for the src directoryβ
Add an alias object to your config:
export default defineNuxtConfig({
  devtools: { enabled: true }, // Not FSD related, enabled at project startup
  alias: {
    "@": '../src'
  },
})
Choose how to configure the routerβ
In NuxtJS, there are two ways to customize the routing - using a config and using a file structure.
In the case of file-based routing, you will create index.vue files in folders inside the app/routes directory, and in the case of configure, you will configure the routers in the router.options.ts file.
Routing using configβ
In the app layer, create a router.options.ts file, and export a config object from it:
import type { RouterConfig } from '@nuxt/schema';
export default <RouterConfig> {
  routes: (_routes) => [],
};
To add a Home page to your project, you need to do the following steps:
- Add a page slice inside the pageslayer
- Add the appropriate route to the app/router.config.tsconfig
To create a page slice, let's use the CLI:
fsd pages home
Create a home-page.vue file inside the ui segment, access it using the Public API
export { default as HomePage } from './ui/home-page';
Thus, the file structure will look like this:
|ββ src
β   βββ app
β   β   βββ router.config.ts
β   βββ pages
β   β   βββ home
β   β   β   βββ ui
β   β   β   β   βββ home-page.vue
β   β   β   βββ index.ts
Finally, let's add a route to the config:
import type { RouterConfig } from '@nuxt/schema'
export default <RouterConfig> {
  routes: (_routes) => [
    {
      name: 'home',
      path: '/',
      component: () => import('@/pages/home.vue').then(r => r.default || r)
    }
  ],
}
File Routingβ
First of all, create a src directory in the root of your project, and create app and pages layers inside this directory and a routes folder inside the app layer.
Thus, your file structure should look like this:
βββ src
β   βββ app
β   β   βββ routes
β   βββ pages                         # Pages folder, related to FSD
In order for NuxtJS to use the routes folder inside the app layer for file routing, you need to modify nuxt.config.ts as follows:
export default defineNuxtConfig({
  devtools: { enabled: true }, // Not FSD related, enabled at project startup
  alias: {
    "@": '../src'
  },
  dir: {
    pages: './src/app/routes'
  }
})
Now, you can create routes for pages within app and connect pages from pages to them.
For example, to add a Home page to your project, you need to do the following steps:
- Add a page slice inside the pageslayer
- Add the corresponding route inside the applayer
- Connect the page from the slice with the route
To create a page slice, let's use the CLI:
fsd pages home
Create a home-page.vue file inside the ui segment, access it using the Public API
export { default as HomePage } from './ui/home-page';
Create a route for this page inside the app layer:
βββ src
β   βββ app
β   β   βββ routes
β   β   β   βββ index.vue
β   βββ pages
β   β   βββ home
β   β   β   βββ ui
β   β   β   β   βββ home-page.vue
β   β   β   βββ index.ts
Add your page component inside the index.vue file:
<script setup>
  import { HomePage } from '@/pages/home';
</script>
<template>
  <HomePage/>
</template>
What to do with layouts?β
You can place layouts inside the app layer, to do this you need to modify the config as follows:
export default defineNuxtConfig({
  devtools: { enabled: true }, // Not related to FSD, enabled at project startup
  alias: {
    "@": '../src'
  },
  dir: {
    pages: './src/app/routes',
    layouts: './src/app/layouts'
  }
})