[{"data":1,"prerenderedAt":6376},["ShallowReactive",2],{"$fGCo9l1hMtNdUiA6QzdUX5X3kLqaWcC5t2kdz4LrvCvc":3,"versions":2842,"-docs-3-x-directory-structure-components":2847,"-docs-3-x-directory-structure-components-surround":6371},[4,1120,1940,2753],{"title":5,"titleTemplate":6,"icon":7,"path":8,"stem":9,"children":10,"page":108},"Docs",null,"i-lucide-book-marked","/docs/3.x","docs/3.x",[11,109,246,426,907,999,1036,1078],{"title":12,"titleTemplate":13,"icon":14,"path":15,"stem":16,"children":17,"page":108},"Get Started","%s · Get Started with Nuxt","i-lucide-rocket","/docs/3.x/getting-started","docs/3.x/1.getting-started",[18,23,28,33,38,43,48,53,58,63,68,73,78,83,88,93,98,103],{"title":19,"path":20,"stem":21,"titleTemplate":6,"icon":22},"Introduction","/docs/3.x/getting-started/introduction","docs/3.x/1.getting-started/01.introduction","i-lucide-info",{"title":24,"path":25,"stem":26,"titleTemplate":6,"icon":27},"Installation","/docs/3.x/getting-started/installation","docs/3.x/1.getting-started/02.installation","i-lucide-play",{"title":29,"path":30,"stem":31,"titleTemplate":6,"icon":32},"Configuration","/docs/3.x/getting-started/configuration","docs/3.x/1.getting-started/03.configuration","i-lucide-cog",{"title":34,"path":35,"stem":36,"titleTemplate":6,"icon":37},"Views","/docs/3.x/getting-started/views","docs/3.x/1.getting-started/04.views","i-lucide-panels-top-left",{"title":39,"path":40,"stem":41,"titleTemplate":6,"icon":42},"Assets","/docs/3.x/getting-started/assets","docs/3.x/1.getting-started/05.assets","i-lucide-image",{"title":44,"path":45,"stem":46,"titleTemplate":6,"icon":47},"Styling","/docs/3.x/getting-started/styling","docs/3.x/1.getting-started/06.styling","i-lucide-palette",{"title":49,"path":50,"stem":51,"titleTemplate":6,"icon":52},"Routing","/docs/3.x/getting-started/routing","docs/3.x/1.getting-started/07.routing","i-lucide-milestone",{"title":54,"path":55,"stem":56,"titleTemplate":6,"icon":57},"SEO and Meta","/docs/3.x/getting-started/seo-meta","docs/3.x/1.getting-started/08.seo-meta","i-lucide-file-search",{"title":59,"path":60,"stem":61,"titleTemplate":6,"icon":62},"Transitions","/docs/3.x/getting-started/transitions","docs/3.x/1.getting-started/09.transitions","i-lucide-toggle-right",{"title":64,"path":65,"stem":66,"titleTemplate":6,"icon":67},"Data Fetching","/docs/3.x/getting-started/data-fetching","docs/3.x/1.getting-started/10.data-fetching","i-lucide-cable",{"title":69,"path":70,"stem":71,"titleTemplate":6,"icon":72},"State Management","/docs/3.x/getting-started/state-management","docs/3.x/1.getting-started/11.state-management","i-lucide-database",{"title":74,"path":75,"stem":76,"titleTemplate":6,"icon":77},"Error Handling","/docs/3.x/getting-started/error-handling","docs/3.x/1.getting-started/12.error-handling","i-lucide-bug-off",{"title":79,"path":80,"stem":81,"titleTemplate":6,"icon":82},"Server","/docs/3.x/getting-started/server","docs/3.x/1.getting-started/13.server","i-lucide-pc-case",{"title":84,"path":85,"stem":86,"titleTemplate":6,"icon":87},"Layers","/docs/3.x/getting-started/layers","docs/3.x/1.getting-started/14.layers","i-lucide-layers",{"title":89,"path":90,"stem":91,"titleTemplate":6,"icon":92},"Prerendering","/docs/3.x/getting-started/prerendering","docs/3.x/1.getting-started/15.prerendering","i-lucide-file-code-2",{"title":94,"path":95,"stem":96,"titleTemplate":6,"icon":97},"Deployment","/docs/3.x/getting-started/deployment","docs/3.x/1.getting-started/16.deployment","i-lucide-cloud",{"title":99,"path":100,"stem":101,"titleTemplate":6,"icon":102},"Testing","/docs/3.x/getting-started/testing","docs/3.x/1.getting-started/17.testing","i-lucide-circle-check",{"title":104,"path":105,"stem":106,"titleTemplate":6,"icon":107},"Upgrade Guide","/docs/3.x/getting-started/upgrade","docs/3.x/1.getting-started/18.upgrade","i-lucide-circle-arrow-up",false,{"title":110,"titleTemplate":111,"icon":112,"path":113,"stem":114,"children":115,"page":108},"Directory Structure","%s · Nuxt Directory Structure","i-vscode-icons-default-folder","/docs/3.x/directory-structure","docs/3.x/2.directory-structure",[116,121,126,131,136,141,146,151,156,161,165,170,174,179,184,189,194,199,204,209,214,218,223,228,232,236,241],{"title":117,"path":118,"stem":119,"titleTemplate":6,"icon":120},".nuxt","/docs/3.x/directory-structure/nuxt","docs/3.x/2.directory-structure/0.nuxt","i-vscode-icons-folder-type-temp",{"title":122,"path":123,"stem":124,"titleTemplate":6,"icon":125},".output","/docs/3.x/directory-structure/output","docs/3.x/2.directory-structure/0.output","i-vscode-icons-folder-type-package",{"title":127,"path":128,"stem":129,"titleTemplate":6,"icon":130},"assets","/docs/3.x/directory-structure/assets","docs/3.x/2.directory-structure/1.assets","i-vscode-icons-folder-type-asset",{"title":132,"path":133,"stem":134,"titleTemplate":6,"icon":135},"components","/docs/3.x/directory-structure/components","docs/3.x/2.directory-structure/1.components","i-vscode-icons-folder-type-component",{"title":137,"path":138,"stem":139,"titleTemplate":6,"icon":140},"composables","/docs/3.x/directory-structure/composables","docs/3.x/2.directory-structure/1.composables","i-vscode-icons-folder-type-src",{"title":142,"path":143,"stem":144,"titleTemplate":6,"icon":145},"content","/docs/3.x/directory-structure/content","docs/3.x/2.directory-structure/1.content","i-vscode-icons-folder-type-log",{"title":147,"path":148,"stem":149,"titleTemplate":6,"icon":150},"layers","/docs/3.x/directory-structure/layers","docs/3.x/2.directory-structure/1.layers","i-vscode-icons-folder-type-nuxt",{"title":152,"path":153,"stem":154,"titleTemplate":6,"icon":155},"layouts","/docs/3.x/directory-structure/layouts","docs/3.x/2.directory-structure/1.layouts","i-vscode-icons-folder-type-view",{"title":157,"path":158,"stem":159,"titleTemplate":6,"icon":160},"middleware","/docs/3.x/directory-structure/middleware","docs/3.x/2.directory-structure/1.middleware","i-vscode-icons-folder-type-middleware",{"title":162,"path":163,"stem":164,"titleTemplate":6,"icon":150},"modules","/docs/3.x/directory-structure/modules","docs/3.x/2.directory-structure/1.modules",{"title":166,"path":167,"stem":168,"titleTemplate":6,"icon":169},"node_modules","/docs/3.x/directory-structure/node_modules","docs/3.x/2.directory-structure/1.node_modules","i-vscode-icons-folder-type-node",{"title":171,"path":172,"stem":173,"titleTemplate":6,"icon":155},"pages","/docs/3.x/directory-structure/pages","docs/3.x/2.directory-structure/1.pages",{"title":175,"path":176,"stem":177,"titleTemplate":6,"icon":178},"plugins","/docs/3.x/directory-structure/plugins","docs/3.x/2.directory-structure/1.plugins","i-vscode-icons-folder-type-plugin",{"title":180,"path":181,"stem":182,"titleTemplate":6,"icon":183},"public","/docs/3.x/directory-structure/public","docs/3.x/2.directory-structure/1.public","i-vscode-icons-folder-type-public",{"title":185,"path":186,"stem":187,"titleTemplate":6,"icon":188},"server","/docs/3.x/directory-structure/server","docs/3.x/2.directory-structure/1.server","i-vscode-icons-folder-type-server",{"title":190,"path":191,"stem":192,"titleTemplate":6,"icon":193},"shared","/docs/3.x/directory-structure/shared","docs/3.x/2.directory-structure/1.shared","i-vscode-icons-folder-type-shared",{"title":195,"path":196,"stem":197,"titleTemplate":6,"icon":198},"utils","/docs/3.x/directory-structure/utils","docs/3.x/2.directory-structure/1.utils","i-vscode-icons-folder-type-tools",{"title":200,"path":201,"stem":202,"titleTemplate":6,"icon":203},".env","/docs/3.x/directory-structure/env","docs/3.x/2.directory-structure/2.env","i-vscode-icons-file-type-dotenv",{"title":205,"path":206,"stem":207,"titleTemplate":6,"icon":208},".gitignore","/docs/3.x/directory-structure/gitignore","docs/3.x/2.directory-structure/2.gitignore","i-vscode-icons-file-type-git",{"title":210,"path":211,"stem":212,"titleTemplate":6,"icon":213},".nuxtignore","/docs/3.x/directory-structure/nuxtignore","docs/3.x/2.directory-structure/2.nuxtignore","i-vscode-icons-file-type-nuxt",{"title":215,"path":216,"stem":217,"titleTemplate":6,"icon":213},".nuxtrc","/docs/3.x/directory-structure/nuxtrc","docs/3.x/2.directory-structure/2.nuxtrc",{"title":219,"path":220,"stem":221,"titleTemplate":6,"icon":222},"app.vue","/docs/3.x/directory-structure/app","docs/3.x/2.directory-structure/3.app","i-vscode-icons-file-type-vue",{"title":224,"path":225,"stem":226,"titleTemplate":6,"icon":227},"app.config.ts","/docs/3.x/directory-structure/app-config","docs/3.x/2.directory-structure/3.app-config","i-vscode-icons-file-type-light-config",{"title":229,"path":230,"stem":231,"titleTemplate":6,"icon":222},"error.vue","/docs/3.x/directory-structure/error","docs/3.x/2.directory-structure/3.error",{"title":233,"path":234,"stem":235,"titleTemplate":6,"icon":213},"nuxt.config.ts","/docs/3.x/directory-structure/nuxt-config","docs/3.x/2.directory-structure/3.nuxt-config",{"title":237,"path":238,"stem":239,"titleTemplate":6,"icon":240},"package.json","/docs/3.x/directory-structure/package","docs/3.x/2.directory-structure/3.package","i-vscode-icons-file-type-npm",{"title":242,"path":243,"stem":244,"titleTemplate":6,"icon":245},"tsconfig.json","/docs/3.x/directory-structure/tsconfig","docs/3.x/2.directory-structure/3.tsconfig","i-vscode-icons-file-type-tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":249,"stem":250,"children":251,"page":108},"Guide","i-lucide-book-open","/docs/3.x/guide","docs/3.x/3.guide",[252,287,306,321,356,379],{"title":253,"titleTemplate":254,"icon":255,"path":256,"stem":257,"children":258,"page":108},"Key Concepts","%s · Nuxt Concepts","i-lucide-medal","/docs/3.x/guide/concepts","docs/3.x/3.guide/1.concepts",[259,263,267,271,275,279,283],{"title":260,"path":261,"stem":262,"titleTemplate":6},"Rendering Modes","/docs/3.x/guide/concepts/rendering","docs/3.x/3.guide/1.concepts/1.rendering",{"title":264,"path":265,"stem":266,"titleTemplate":6},"Nuxt Lifecycle","/docs/3.x/guide/concepts/nuxt-lifecycle","docs/3.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":269,"stem":270,"titleTemplate":6},"Auto-imports","/docs/3.x/guide/concepts/auto-imports","docs/3.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":273,"stem":274,"titleTemplate":6},"Server Engine","/docs/3.x/guide/concepts/server-engine","docs/3.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":277,"stem":278,"titleTemplate":6},"Modules","/docs/3.x/guide/concepts/modules","docs/3.x/3.guide/1.concepts/5.modules",{"title":280,"path":281,"stem":282,"titleTemplate":6},"TypeScript","/docs/3.x/guide/concepts/typescript","docs/3.x/3.guide/1.concepts/8.typescript",{"title":284,"path":285,"stem":286,"titleTemplate":6},"Code Style","/docs/3.x/guide/concepts/code-style","docs/3.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":291,"stem":292,"children":293,"page":108},"Best Practices","%s · Best Practices","i-lucide-square-check","/docs/3.x/guide/best-practices","docs/3.x/3.guide/2.best-practices",[294,298,302],{"title":295,"path":296,"stem":297,"titleTemplate":6},"Nuxt and hydration","/docs/3.x/guide/best-practices/hydration","docs/3.x/3.guide/2.best-practices/hydration",{"title":299,"path":300,"stem":301,"titleTemplate":6},"Nuxt Performance","/docs/3.x/guide/best-practices/performance","docs/3.x/3.guide/2.best-practices/performance",{"title":303,"path":304,"stem":305,"titleTemplate":6},"Nuxt Plugins","/docs/3.x/guide/best-practices/plugins","docs/3.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":310,"stem":311,"children":312,"page":108},"Working with AI","Working with AI: %s","i-lucide-bot","/docs/3.x/guide/ai","docs/3.x/3.guide/3.ai",[313,317],{"title":314,"path":315,"stem":316,"titleTemplate":6},"MCP Server","/docs/3.x/guide/ai/mcp","docs/3.x/3.guide/3.ai/1.mcp",{"title":318,"path":319,"stem":320,"titleTemplate":6},"LLMs.txt","/docs/3.x/guide/ai/llms-txt","docs/3.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":325,"stem":326,"children":327,"page":108},"Module Author Guide","%s · Nuxt Modules Author Guide","i-lucide-box","/docs/3.x/guide/modules","docs/3.x/3.guide/4.modules",[328,332,336,340,344,348,352],{"title":329,"path":330,"stem":331,"titleTemplate":6},"Create Your First Module","/docs/3.x/guide/modules/getting-started","docs/3.x/3.guide/4.modules/1.getting-started",{"title":333,"path":334,"stem":335,"titleTemplate":6},"Understand Module Structure","/docs/3.x/guide/modules/module-anatomy","docs/3.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":338,"stem":339,"titleTemplate":6},"Add Plugins, Components & More","/docs/3.x/guide/modules/recipes-basics","docs/3.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":342,"stem":343,"titleTemplate":6},"Use Hooks & Extend Types","/docs/3.x/guide/modules/recipes-advanced","docs/3.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":346,"stem":347,"titleTemplate":6},"Test Your Module","/docs/3.x/guide/modules/testing","docs/3.x/3.guide/4.modules/5.testing",{"title":349,"path":350,"stem":351,"titleTemplate":6},"Follow Best Practices","/docs/3.x/guide/modules/best-practices","docs/3.x/3.guide/4.modules/6.best-practices",{"title":353,"path":354,"stem":355,"titleTemplate":6},"Publish & Share Your Module","/docs/3.x/guide/modules/ecosystem","docs/3.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":360,"stem":361,"children":362,"page":108},"Recipes","%s · Recipes","i-lucide-cooking-pot","/docs/3.x/guide/recipes","docs/3.x/3.guide/5.recipes",[363,367,371,375],{"title":364,"path":365,"stem":366,"titleTemplate":6},"Custom Routing","/docs/3.x/guide/recipes/custom-routing","docs/3.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":369,"stem":370,"titleTemplate":6},"Vite Plugins","/docs/3.x/guide/recipes/vite-plugin","docs/3.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":373,"stem":374,"titleTemplate":6},"Custom useFetch","/docs/3.x/guide/recipes/custom-usefetch","docs/3.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":377,"stem":378,"titleTemplate":6},"Sessions and Authentication","/docs/3.x/guide/recipes/sessions-and-authentication","docs/3.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":383,"stem":384,"children":385,"page":108},"Going Further","%s · Nuxt Advanced","i-lucide-star","/docs/3.x/guide/going-further","docs/3.x/3.guide/6.going-further",[386,390,394,398,402,406,410,414,418,422],{"title":387,"path":388,"stem":389,"titleTemplate":6},"Custom Events","/docs/3.x/guide/going-further/events","docs/3.x/3.guide/6.going-further/1.events",{"title":391,"path":392,"stem":393,"titleTemplate":6},"Experimental Features","/docs/3.x/guide/going-further/experimental-features","docs/3.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":396,"stem":397,"titleTemplate":6},"Features","/docs/3.x/guide/going-further/features","docs/3.x/3.guide/6.going-further/1.features",{"title":399,"path":400,"stem":401,"titleTemplate":6},"Runtime Config","/docs/3.x/guide/going-further/runtime-config","docs/3.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":404,"stem":405,"titleTemplate":6},"Nightly Release Channel","/docs/3.x/guide/going-further/nightly-release-channel","docs/3.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":408,"stem":409,"titleTemplate":6},"Lifecycle Hooks","/docs/3.x/guide/going-further/hooks","docs/3.x/3.guide/6.going-further/2.hooks",{"title":411,"path":412,"stem":413,"titleTemplate":6},"Nuxt Kit","/docs/3.x/guide/going-further/kit","docs/3.x/3.guide/6.going-further/4.kit",{"title":415,"path":416,"stem":417,"titleTemplate":6},"NuxtApp","/docs/3.x/guide/going-further/nuxt-app","docs/3.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":420,"stem":421,"titleTemplate":6},"Authoring Nuxt Layers","/docs/3.x/guide/going-further/layers","docs/3.x/3.guide/6.going-further/7.layers",{"title":423,"path":424,"stem":425,"titleTemplate":6},"Debugging","/docs/3.x/guide/going-further/debugging","docs/3.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":430,"stem":431,"children":432,"page":108},"API","%s · Nuxt API","i-lucide-code-xml","/docs/3.x/api","docs/3.x/4.api",[433,499,622,745,816,889,902],{"title":434,"titleTemplate":435,"icon":324,"path":436,"stem":437,"children":438,"page":108},"Components","%s · Nuxt Components","/docs/3.x/api/components","docs/3.x/4.api/1.components",[439,443,447,451,455,459,463,467,471,475,479,483,487,491,495],{"title":440,"path":441,"stem":442,"titleTemplate":6},"\u003CClientOnly>","/docs/3.x/api/components/client-only","docs/3.x/4.api/1.components/1.client-only",{"title":444,"path":445,"stem":446,"titleTemplate":6},"\u003CDevOnly>","/docs/3.x/api/components/dev-only","docs/3.x/4.api/1.components/1.dev-only",{"title":448,"path":449,"stem":450,"titleTemplate":6},"\u003CNuxtClientFallback>","/docs/3.x/api/components/nuxt-client-fallback","docs/3.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":453,"stem":454,"titleTemplate":6},"\u003CNuxtPicture>","/docs/3.x/api/components/nuxt-picture","docs/3.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":457,"stem":458,"titleTemplate":6},"\u003CTeleport>","/docs/3.x/api/components/teleports","docs/3.x/4.api/1.components/11.teleports",{"title":460,"path":461,"stem":462,"titleTemplate":6},"\u003CNuxtRouteAnnouncer>","/docs/3.x/api/components/nuxt-route-announcer","docs/3.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":465,"stem":466,"titleTemplate":6},"\u003CNuxtTime>","/docs/3.x/api/components/nuxt-time","docs/3.x/4.api/1.components/13.nuxt-time",{"title":468,"path":469,"stem":470,"titleTemplate":6},"\u003CNuxtPage>","/docs/3.x/api/components/nuxt-page","docs/3.x/4.api/1.components/2.nuxt-page",{"title":472,"path":473,"stem":474,"titleTemplate":6},"\u003CNuxtLayout>","/docs/3.x/api/components/nuxt-layout","docs/3.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":477,"stem":478,"titleTemplate":6},"\u003CNuxtLink>","/docs/3.x/api/components/nuxt-link","docs/3.x/4.api/1.components/4.nuxt-link",{"title":480,"path":481,"stem":482,"titleTemplate":6},"\u003CNuxtLoadingIndicator>","/docs/3.x/api/components/nuxt-loading-indicator","docs/3.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":485,"stem":486,"titleTemplate":6},"\u003CNuxtErrorBoundary>","/docs/3.x/api/components/nuxt-error-boundary","docs/3.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":489,"stem":490,"titleTemplate":6},"\u003CNuxtWelcome>","/docs/3.x/api/components/nuxt-welcome","docs/3.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":493,"stem":494,"titleTemplate":6},"\u003CNuxtIsland>","/docs/3.x/api/components/nuxt-island","docs/3.x/4.api/1.components/8.nuxt-island",{"title":496,"path":497,"stem":498,"titleTemplate":6},"\u003CNuxtImg>","/docs/3.x/api/components/nuxt-img","docs/3.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":503,"stem":504,"children":505,"page":108},"Composables","%s · Nuxt Composables","i-lucide-arrow-left-right","/docs/3.x/api/composables","docs/3.x/4.api/2.composables",[506,510,514,518,522,526,530,534,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618],{"title":507,"path":508,"stem":509,"titleTemplate":6},"onPrehydrate","/docs/3.x/api/composables/on-prehydrate","docs/3.x/4.api/2.composables/on-prehydrate",{"title":511,"path":512,"stem":513,"titleTemplate":6},"useAppConfig","/docs/3.x/api/composables/use-app-config","docs/3.x/4.api/2.composables/use-app-config",{"title":515,"path":516,"stem":517,"titleTemplate":6},"useAsyncData","/docs/3.x/api/composables/use-async-data","docs/3.x/4.api/2.composables/use-async-data",{"title":519,"path":520,"stem":521,"titleTemplate":6},"useCookie","/docs/3.x/api/composables/use-cookie","docs/3.x/4.api/2.composables/use-cookie",{"title":523,"path":524,"stem":525,"titleTemplate":6},"useError","/docs/3.x/api/composables/use-error","docs/3.x/4.api/2.composables/use-error",{"title":527,"path":528,"stem":529,"titleTemplate":6},"useFetch","/docs/3.x/api/composables/use-fetch","docs/3.x/4.api/2.composables/use-fetch",{"title":531,"path":532,"stem":533,"titleTemplate":6},"useHead","/docs/3.x/api/composables/use-head","docs/3.x/4.api/2.composables/use-head",{"title":535,"path":536,"stem":537,"titleTemplate":6},"useHeadSafe","/docs/3.x/api/composables/use-head-safe","docs/3.x/4.api/2.composables/use-head-safe",{"title":539,"path":540,"stem":541,"titleTemplate":6},"useHydration","/docs/3.x/api/composables/use-hydration","docs/3.x/4.api/2.composables/use-hydration",{"title":543,"path":544,"stem":545,"titleTemplate":6},"useLazyAsyncData","/docs/3.x/api/composables/use-lazy-async-data","docs/3.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":548,"stem":549,"titleTemplate":6},"useLazyFetch","/docs/3.x/api/composables/use-lazy-fetch","docs/3.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":552,"stem":553,"titleTemplate":6},"useLoadingIndicator","/docs/3.x/api/composables/use-loading-indicator","docs/3.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":556,"stem":557,"titleTemplate":6},"useNuxtApp","/docs/3.x/api/composables/use-nuxt-app","docs/3.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":560,"stem":561,"titleTemplate":6},"useNuxtData","/docs/3.x/api/composables/use-nuxt-data","docs/3.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":564,"stem":565,"titleTemplate":6},"usePreviewMode","/docs/3.x/api/composables/use-preview-mode","docs/3.x/4.api/2.composables/use-preview-mode",{"title":567,"path":568,"stem":569,"titleTemplate":6},"useRequestEvent","/docs/3.x/api/composables/use-request-event","docs/3.x/4.api/2.composables/use-request-event",{"title":571,"path":572,"stem":573,"titleTemplate":6},"useRequestFetch","/docs/3.x/api/composables/use-request-fetch","docs/3.x/4.api/2.composables/use-request-fetch",{"title":575,"path":576,"stem":577,"titleTemplate":6},"useRequestHeader","/docs/3.x/api/composables/use-request-header","docs/3.x/4.api/2.composables/use-request-header",{"title":579,"path":580,"stem":581,"titleTemplate":6},"useRequestHeaders","/docs/3.x/api/composables/use-request-headers","docs/3.x/4.api/2.composables/use-request-headers",{"title":583,"path":584,"stem":585,"titleTemplate":6},"useRequestURL","/docs/3.x/api/composables/use-request-url","docs/3.x/4.api/2.composables/use-request-url",{"title":587,"path":588,"stem":589,"titleTemplate":6},"useResponseHeader","/docs/3.x/api/composables/use-response-header","docs/3.x/4.api/2.composables/use-response-header",{"title":591,"path":592,"stem":593,"titleTemplate":6},"useRoute","/docs/3.x/api/composables/use-route","docs/3.x/4.api/2.composables/use-route",{"title":595,"path":596,"stem":597,"titleTemplate":6},"useRouteAnnouncer","/docs/3.x/api/composables/use-route-announcer","docs/3.x/4.api/2.composables/use-route-announcer",{"title":599,"path":600,"stem":601,"titleTemplate":6},"useRouter","/docs/3.x/api/composables/use-router","docs/3.x/4.api/2.composables/use-router",{"title":603,"path":604,"stem":605,"titleTemplate":6},"useRuntimeConfig","/docs/3.x/api/composables/use-runtime-config","docs/3.x/4.api/2.composables/use-runtime-config",{"title":607,"path":608,"stem":609,"titleTemplate":6},"useRuntimeHook","/docs/3.x/api/composables/use-runtime-hook","docs/3.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":612,"stem":613,"titleTemplate":6},"useSeoMeta","/docs/3.x/api/composables/use-seo-meta","docs/3.x/4.api/2.composables/use-seo-meta",{"title":615,"path":616,"stem":617,"titleTemplate":6},"useServerSeoMeta","/docs/3.x/api/composables/use-server-seo-meta","docs/3.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":620,"stem":621,"titleTemplate":6},"useState","/docs/3.x/api/composables/use-state","docs/3.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":626,"stem":627,"children":628,"page":108},"Utils","%s · Nuxt Utils","i-lucide-square-function","/docs/3.x/api/utils","docs/3.x/4.api/3.utils",[629,633,637,641,645,649,653,657,661,665,669,673,677,681,685,689,693,697,701,705,709,713,717,721,725,729,733,737,741],{"title":630,"path":631,"stem":632,"titleTemplate":6},"$fetch","/docs/3.x/api/utils/dollarfetch","docs/3.x/4.api/3.utils/$fetch",{"title":634,"path":635,"stem":636,"titleTemplate":6},"abortNavigation","/docs/3.x/api/utils/abort-navigation","docs/3.x/4.api/3.utils/abort-navigation",{"title":638,"path":639,"stem":640,"titleTemplate":6},"addRouteMiddleware","/docs/3.x/api/utils/add-route-middleware","docs/3.x/4.api/3.utils/add-route-middleware",{"title":642,"path":643,"stem":644,"titleTemplate":6},"callOnce","/docs/3.x/api/utils/call-once","docs/3.x/4.api/3.utils/call-once",{"title":646,"path":647,"stem":648,"titleTemplate":6},"clearError","/docs/3.x/api/utils/clear-error","docs/3.x/4.api/3.utils/clear-error",{"title":650,"path":651,"stem":652,"titleTemplate":6},"clearNuxtData","/docs/3.x/api/utils/clear-nuxt-data","docs/3.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":655,"stem":656,"titleTemplate":6},"clearNuxtState","/docs/3.x/api/utils/clear-nuxt-state","docs/3.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":659,"stem":660,"titleTemplate":6},"createError","/docs/3.x/api/utils/create-error","docs/3.x/4.api/3.utils/create-error",{"title":662,"path":663,"stem":664,"titleTemplate":6},"defineLazyHydrationComponent","/docs/3.x/api/utils/define-lazy-hydration-component","docs/3.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":667,"stem":668,"titleTemplate":6},"defineNuxtComponent","/docs/3.x/api/utils/define-nuxt-component","docs/3.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":671,"stem":672,"titleTemplate":6},"defineNuxtPlugin","/docs/3.x/api/utils/define-nuxt-plugin","docs/3.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":675,"stem":676,"titleTemplate":6},"defineNuxtRouteMiddleware","/docs/3.x/api/utils/define-nuxt-route-middleware","docs/3.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":679,"stem":680,"titleTemplate":6},"definePageMeta","/docs/3.x/api/utils/define-page-meta","docs/3.x/4.api/3.utils/define-page-meta",{"title":682,"path":683,"stem":684,"titleTemplate":6},"defineRouteRules","/docs/3.x/api/utils/define-route-rules","docs/3.x/4.api/3.utils/define-route-rules",{"title":686,"path":687,"stem":688,"titleTemplate":6},"navigateTo","/docs/3.x/api/utils/navigate-to","docs/3.x/4.api/3.utils/navigate-to",{"title":690,"path":691,"stem":692,"titleTemplate":6},"onBeforeRouteLeave","/docs/3.x/api/utils/on-before-route-leave","docs/3.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":695,"stem":696,"titleTemplate":6},"onBeforeRouteUpdate","/docs/3.x/api/utils/on-before-route-update","docs/3.x/4.api/3.utils/on-before-route-update",{"title":698,"path":699,"stem":700,"titleTemplate":6},"onNuxtReady","/docs/3.x/api/utils/on-nuxt-ready","docs/3.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":703,"stem":704,"titleTemplate":6},"prefetchComponents","/docs/3.x/api/utils/prefetch-components","docs/3.x/4.api/3.utils/prefetch-components",{"title":706,"path":707,"stem":708,"titleTemplate":6},"preloadComponents","/docs/3.x/api/utils/preload-components","docs/3.x/4.api/3.utils/preload-components",{"title":710,"path":711,"stem":712,"titleTemplate":6},"preloadRouteComponents","/docs/3.x/api/utils/preload-route-components","docs/3.x/4.api/3.utils/preload-route-components",{"title":714,"path":715,"stem":716,"titleTemplate":6},"prerenderRoutes","/docs/3.x/api/utils/prerender-routes","docs/3.x/4.api/3.utils/prerender-routes",{"title":718,"path":719,"stem":720,"titleTemplate":6},"refreshCookie","/docs/3.x/api/utils/refresh-cookie","docs/3.x/4.api/3.utils/refresh-cookie",{"title":722,"path":723,"stem":724,"titleTemplate":6},"refreshNuxtData","/docs/3.x/api/utils/refresh-nuxt-data","docs/3.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":727,"stem":728,"titleTemplate":6},"reloadNuxtApp","/docs/3.x/api/utils/reload-nuxt-app","docs/3.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":731,"stem":732,"titleTemplate":6},"setPageLayout","/docs/3.x/api/utils/set-page-layout","docs/3.x/4.api/3.utils/set-page-layout",{"title":734,"path":735,"stem":736,"titleTemplate":6},"setResponseStatus","/docs/3.x/api/utils/set-response-status","docs/3.x/4.api/3.utils/set-response-status",{"title":738,"path":739,"stem":740,"titleTemplate":6},"showError","/docs/3.x/api/utils/show-error","docs/3.x/4.api/3.utils/show-error",{"title":742,"path":743,"stem":744,"titleTemplate":6},"updateAppConfig","/docs/3.x/api/utils/update-app-config","docs/3.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":749,"stem":750,"children":751,"page":108},"Commands","%s · Nuxt Commands","i-lucide-square-terminal","/docs/3.x/api/commands","docs/3.x/4.api/4.commands",[752,756,760,764,768,772,776,780,784,788,792,796,800,804,808,812],{"title":753,"path":754,"stem":755,"titleTemplate":6},"nuxt add","/docs/3.x/api/commands/add","docs/3.x/4.api/4.commands/add",{"title":757,"path":758,"stem":759,"titleTemplate":6},"nuxt analyze","/docs/3.x/api/commands/analyze","docs/3.x/4.api/4.commands/analyze",{"title":761,"path":762,"stem":763,"titleTemplate":6},"nuxt build","/docs/3.x/api/commands/build","docs/3.x/4.api/4.commands/build",{"title":765,"path":766,"stem":767,"titleTemplate":6},"nuxt build-module","/docs/3.x/api/commands/build-module","docs/3.x/4.api/4.commands/build-module",{"title":769,"path":770,"stem":771,"titleTemplate":6},"nuxt cleanup","/docs/3.x/api/commands/cleanup","docs/3.x/4.api/4.commands/cleanup",{"title":773,"path":774,"stem":775,"titleTemplate":6},"nuxt dev","/docs/3.x/api/commands/dev","docs/3.x/4.api/4.commands/dev",{"title":777,"path":778,"stem":779,"titleTemplate":6},"nuxt devtools","/docs/3.x/api/commands/devtools","docs/3.x/4.api/4.commands/devtools",{"title":781,"path":782,"stem":783,"titleTemplate":6},"nuxt generate","/docs/3.x/api/commands/generate","docs/3.x/4.api/4.commands/generate",{"title":785,"path":786,"stem":787,"titleTemplate":6},"nuxt info","/docs/3.x/api/commands/info","docs/3.x/4.api/4.commands/info",{"title":789,"path":790,"stem":791,"titleTemplate":6},"create nuxt","/docs/3.x/api/commands/init","docs/3.x/4.api/4.commands/init",{"title":793,"path":794,"stem":795,"titleTemplate":6},"nuxt module","/docs/3.x/api/commands/module","docs/3.x/4.api/4.commands/module",{"title":797,"path":798,"stem":799,"titleTemplate":6},"nuxt prepare","/docs/3.x/api/commands/prepare","docs/3.x/4.api/4.commands/prepare",{"title":801,"path":802,"stem":803,"titleTemplate":6},"nuxt preview","/docs/3.x/api/commands/preview","docs/3.x/4.api/4.commands/preview",{"title":805,"path":806,"stem":807,"titleTemplate":6},"nuxt test","/docs/3.x/api/commands/test","docs/3.x/4.api/4.commands/test",{"title":809,"path":810,"stem":811,"titleTemplate":6},"nuxt typecheck","/docs/3.x/api/commands/typecheck","docs/3.x/4.api/4.commands/typecheck",{"title":813,"path":814,"stem":815,"titleTemplate":6},"nuxt upgrade","/docs/3.x/api/commands/upgrade","docs/3.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":819,"stem":820,"children":821,"page":108},"%s · Nuxt Kit","i-lucide-package","/docs/3.x/api/kit","docs/3.x/4.api/5.kit",[822,825,828,832,836,840,844,848,852,855,859,863,866,869,873,877,881,885],{"title":276,"path":823,"stem":824,"titleTemplate":6},"/docs/3.x/api/kit/modules","docs/3.x/4.api/5.kit/1.modules",{"title":399,"path":826,"stem":827,"titleTemplate":6},"/docs/3.x/api/kit/runtime-config","docs/3.x/4.api/5.kit/10.runtime-config",{"title":829,"path":830,"stem":831,"titleTemplate":6},"Templates","/docs/3.x/api/kit/templates","docs/3.x/4.api/5.kit/10.templates",{"title":833,"path":834,"stem":835,"titleTemplate":6},"Nitro","/docs/3.x/api/kit/nitro","docs/3.x/4.api/5.kit/11.nitro",{"title":837,"path":838,"stem":839,"titleTemplate":6},"Resolving","/docs/3.x/api/kit/resolving","docs/3.x/4.api/5.kit/12.resolving",{"title":841,"path":842,"stem":843,"titleTemplate":6},"Logging","/docs/3.x/api/kit/logging","docs/3.x/4.api/5.kit/13.logging",{"title":845,"path":846,"stem":847,"titleTemplate":6},"Builder","/docs/3.x/api/kit/builder","docs/3.x/4.api/5.kit/14.builder",{"title":849,"path":850,"stem":851,"titleTemplate":6},"Examples","/docs/3.x/api/kit/examples","docs/3.x/4.api/5.kit/15.examples",{"title":84,"path":853,"stem":854,"titleTemplate":6},"/docs/3.x/api/kit/layers","docs/3.x/4.api/5.kit/16.layers",{"title":856,"path":857,"stem":858,"titleTemplate":6},"Programmatic Usage","/docs/3.x/api/kit/programmatic","docs/3.x/4.api/5.kit/2.programmatic",{"title":860,"path":861,"stem":862,"titleTemplate":6},"Compatibility","/docs/3.x/api/kit/compatibility","docs/3.x/4.api/5.kit/3.compatibility",{"title":268,"path":864,"stem":865,"titleTemplate":6},"/docs/3.x/api/kit/autoimports","docs/3.x/4.api/5.kit/4.autoimports",{"title":434,"path":867,"stem":868,"titleTemplate":6},"/docs/3.x/api/kit/components","docs/3.x/4.api/5.kit/5.components",{"title":870,"path":871,"stem":872,"titleTemplate":6},"Context","/docs/3.x/api/kit/context","docs/3.x/4.api/5.kit/6.context",{"title":874,"path":875,"stem":876,"titleTemplate":6},"Pages","/docs/3.x/api/kit/pages","docs/3.x/4.api/5.kit/7.pages",{"title":878,"path":879,"stem":880,"titleTemplate":6},"Layout","/docs/3.x/api/kit/layout","docs/3.x/4.api/5.kit/8.layout",{"title":882,"path":883,"stem":884,"titleTemplate":6},"Head","/docs/3.x/api/kit/head","docs/3.x/4.api/5.kit/9.head",{"title":886,"path":887,"stem":888,"titleTemplate":6},"Plugins","/docs/3.x/api/kit/plugins","docs/3.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":892,"stem":893,"children":894,"page":108},"Advanced","i-lucide-brain","/docs/3.x/api/advanced","docs/3.x/4.api/6.advanced",[895,898],{"title":407,"path":896,"stem":897,"titleTemplate":6},"/docs/3.x/api/advanced/hooks","docs/3.x/4.api/6.advanced/1.hooks",{"title":899,"path":900,"stem":901,"titleTemplate":6},"Import meta","/docs/3.x/api/advanced/import-meta","docs/3.x/4.api/6.advanced/2.import-meta",{"title":903,"path":904,"stem":905,"titleTemplate":906,"icon":32},"Nuxt Configuration","/docs/3.x/api/nuxt-config","docs/3.x/4.api/6.nuxt-config","%s",{"title":849,"titleTemplate":908,"icon":909,"path":910,"stem":911,"children":912,"page":108},"%s · Nuxt Examples","i-lucide-app-window-mac","/docs/3.x/examples","docs/3.x/4.examples",[913,917,939,954,990],{"title":914,"path":915,"stem":916,"titleTemplate":6},"Hello World","/docs/3.x/examples/hello-world","docs/3.x/4.examples/0.hello-world",{"title":395,"path":918,"stem":919,"children":920,"page":108},"/docs/3.x/examples/features","docs/3.x/4.examples/1.features",[921,925,928,931,935],{"title":922,"path":923,"stem":924,"titleTemplate":6},"Auto Imports","/docs/3.x/examples/features/auto-imports","docs/3.x/4.examples/1.features/1.auto-imports",{"title":64,"path":926,"stem":927,"titleTemplate":6},"/docs/3.x/examples/features/data-fetching","docs/3.x/4.examples/1.features/2.data-fetching",{"title":69,"path":929,"stem":930,"titleTemplate":6},"/docs/3.x/examples/features/state-management","docs/3.x/4.examples/1.features/3.state-management",{"title":932,"path":933,"stem":934,"titleTemplate":6},"Meta Tags","/docs/3.x/examples/features/meta-tags","docs/3.x/4.examples/1.features/4.meta-tags",{"title":936,"path":937,"stem":938,"titleTemplate":6},"Layouts","/docs/3.x/examples/features/layouts","docs/3.x/4.examples/1.features/5.layouts",{"title":49,"path":940,"stem":941,"children":942,"page":108},"/docs/3.x/examples/routing","docs/3.x/4.examples/2.routing",[943,947,950],{"title":944,"path":945,"stem":946,"titleTemplate":6},"Middleware","/docs/3.x/examples/routing/middleware","docs/3.x/4.examples/2.routing/middleware",{"title":874,"path":948,"stem":949,"titleTemplate":6},"/docs/3.x/examples/routing/pages","docs/3.x/4.examples/2.routing/pages",{"title":951,"path":952,"stem":953,"titleTemplate":6},"Universal Router","/docs/3.x/examples/routing/universal-router","docs/3.x/4.examples/2.routing/universal-router",{"title":890,"path":955,"stem":956,"children":957,"page":108},"/docs/3.x/examples/advanced","docs/3.x/4.examples/4.advanced",[958,961,964,968,972,976,980,983,986],{"title":84,"path":959,"stem":960,"titleTemplate":6},"/docs/3.x/examples/advanced/config-extends","docs/3.x/4.examples/4.advanced/config-extends",{"title":74,"path":962,"stem":963,"titleTemplate":6},"/docs/3.x/examples/advanced/error-handling","docs/3.x/4.examples/4.advanced/error-handling",{"title":965,"path":966,"stem":967,"titleTemplate":6},"JSX / TSX","/docs/3.x/examples/advanced/jsx","docs/3.x/4.examples/4.advanced/jsx",{"title":969,"path":970,"stem":971,"titleTemplate":6},"Locale","/docs/3.x/examples/advanced/locale","docs/3.x/4.examples/4.advanced/locale",{"title":973,"path":974,"stem":975,"titleTemplate":6},"Module Extend Pages","/docs/3.x/examples/advanced/module-extend-pages","docs/3.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":978,"stem":979,"titleTemplate":6},"Teleport","/docs/3.x/examples/advanced/teleport","docs/3.x/4.examples/4.advanced/teleport",{"title":99,"path":981,"stem":982,"titleTemplate":6},"/docs/3.x/examples/advanced/testing","docs/3.x/4.examples/4.advanced/testing",{"title":519,"path":984,"stem":985,"titleTemplate":6},"/docs/3.x/examples/advanced/use-cookie","docs/3.x/4.examples/4.advanced/use-cookie",{"title":987,"path":988,"stem":989,"titleTemplate":6},"Use Custom Fetch Composable","/docs/3.x/examples/advanced/use-custom-fetch-composable","docs/3.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":992,"stem":993,"children":994,"page":108},"Experimental","/docs/3.x/examples/experimental","docs/3.x/4.examples/7.experimental",[995],{"title":996,"path":997,"stem":998,"titleTemplate":6},"WASM","/docs/3.x/examples/experimental/wasm","docs/3.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1003,"stem":1004,"children":1005,"page":108},"Community","%s · Nuxt Community","i-lucide-messages-square","/docs/3.x/community","docs/3.x/5.community",[1006,1011,1016,1021,1026,1031],{"title":1007,"path":1008,"stem":1009,"titleTemplate":6,"icon":1010},"Getting Help","/docs/3.x/community/getting-help","docs/3.x/5.community/2.getting-help","i-lucide-life-buoy",{"title":1012,"path":1013,"stem":1014,"titleTemplate":6,"icon":1015},"Reporting Bugs","/docs/3.x/community/reporting-bugs","docs/3.x/5.community/3.reporting-bugs","i-lucide-bug",{"title":1017,"path":1018,"stem":1019,"titleTemplate":6,"icon":1020},"Contribution","/docs/3.x/community/contribution","docs/3.x/5.community/4.contribution","i-lucide-git-pull-request",{"title":1022,"path":1023,"stem":1024,"titleTemplate":6,"icon":1025},"Framework","/docs/3.x/community/framework-contribution","docs/3.x/5.community/5.framework-contribution","i-lucide-github",{"title":1027,"path":1028,"stem":1029,"titleTemplate":6,"icon":1030},"Roadmap","/docs/3.x/community/roadmap","docs/3.x/5.community/6.roadmap","i-lucide-map",{"title":1032,"path":1033,"stem":1034,"titleTemplate":6,"icon":1035},"Releases","/docs/3.x/community/changelog","docs/3.x/5.community/7.changelog","i-lucide-bell-dot",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1040,"stem":1041,"children":1042,"page":108},"Migrate to Nuxt Bridge","Migrate to Nuxt Bridge: %s","i-lucide-ship","/docs/3.x/bridge","docs/3.x/6.bridge",[1043,1047,1050,1053,1057,1061,1065,1068,1071,1074],{"title":1044,"path":1045,"stem":1046,"titleTemplate":6},"Overview","/docs/3.x/bridge/overview","docs/3.x/6.bridge/1.overview",{"title":29,"path":1048,"stem":1049,"titleTemplate":6},"/docs/3.x/bridge/configuration","docs/3.x/6.bridge/10.configuration",{"title":280,"path":1051,"stem":1052,"titleTemplate":6},"/docs/3.x/bridge/typescript","docs/3.x/6.bridge/2.typescript",{"title":1054,"path":1055,"stem":1056,"titleTemplate":6},"Legacy Composition API","/docs/3.x/bridge/bridge-composition-api","docs/3.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1059,"stem":1060,"titleTemplate":6},"Plugins and Middleware","/docs/3.x/bridge/plugins-and-middleware","docs/3.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1063,"stem":1064,"titleTemplate":6},"New Composition API","/docs/3.x/bridge/nuxt3-compatible-api","docs/3.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1066,"stem":1067,"titleTemplate":6},"/docs/3.x/bridge/meta","docs/3.x/6.bridge/6.meta",{"title":399,"path":1069,"stem":1070,"titleTemplate":6},"/docs/3.x/bridge/runtime-config","docs/3.x/6.bridge/7.runtime-config",{"title":833,"path":1072,"stem":1073,"titleTemplate":6},"/docs/3.x/bridge/nitro","docs/3.x/6.bridge/8.nitro",{"title":1075,"path":1076,"stem":1077,"titleTemplate":6},"Vite","/docs/3.x/bridge/vite","docs/3.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1081,"stem":1082,"children":1083,"page":108},"Migrate to Nuxt 3","Migrate to Nuxt 3: %s","/docs/3.x/migration","docs/3.x/7.migration",[1084,1087,1091,1094,1097,1100,1103,1106,1109,1113,1117],{"title":1044,"path":1085,"stem":1086,"titleTemplate":6},"/docs/3.x/migration/overview","docs/3.x/7.migration/1.overview",{"title":1088,"path":1089,"stem":1090,"titleTemplate":6},"Build Tooling","/docs/3.x/migration/bundling","docs/3.x/7.migration/10.bundling",{"title":79,"path":1092,"stem":1093,"titleTemplate":6},"/docs/3.x/migration/server","docs/3.x/7.migration/11.server",{"title":29,"path":1095,"stem":1096,"titleTemplate":6},"/docs/3.x/migration/configuration","docs/3.x/7.migration/2.configuration",{"title":276,"path":1098,"stem":1099,"titleTemplate":6},"/docs/3.x/migration/module-authors","docs/3.x/7.migration/20.module-authors",{"title":922,"path":1101,"stem":1102,"titleTemplate":6},"/docs/3.x/migration/auto-imports","docs/3.x/7.migration/3.auto-imports",{"title":932,"path":1104,"stem":1105,"titleTemplate":6},"/docs/3.x/migration/meta","docs/3.x/7.migration/4.meta",{"title":1058,"path":1107,"stem":1108,"titleTemplate":6},"/docs/3.x/migration/plugins-and-middleware","docs/3.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1111,"stem":1112,"titleTemplate":6},"Pages and Layouts","/docs/3.x/migration/pages-and-layouts","docs/3.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1115,"stem":1116,"titleTemplate":6},"Component Options","/docs/3.x/migration/component-options","docs/3.x/7.migration/7.component-options",{"title":399,"path":1118,"stem":1119,"titleTemplate":6},"/docs/3.x/migration/runtime-config","docs/3.x/7.migration/8.runtime-config",{"title":5,"titleTemplate":6,"icon":7,"path":1121,"stem":1122,"children":1123,"page":108},"/docs/4.x","docs/4.x",[1124,1182,1276,1404,1770,1847,1869,1903],{"title":12,"titleTemplate":13,"icon":14,"path":1125,"stem":1126,"children":1127,"page":108},"/docs/4.x/getting-started","docs/4.x/1.getting-started",[1128,1131,1134,1137,1140,1143,1146,1149,1152,1155,1158,1161,1164,1167,1170,1173,1176,1179],{"title":19,"path":1129,"stem":1130,"titleTemplate":6,"icon":22},"/docs/4.x/getting-started/introduction","docs/4.x/1.getting-started/01.introduction",{"title":24,"path":1132,"stem":1133,"titleTemplate":6,"icon":27},"/docs/4.x/getting-started/installation","docs/4.x/1.getting-started/02.installation",{"title":29,"path":1135,"stem":1136,"titleTemplate":6,"icon":32},"/docs/4.x/getting-started/configuration","docs/4.x/1.getting-started/03.configuration",{"title":34,"path":1138,"stem":1139,"titleTemplate":6,"icon":37},"/docs/4.x/getting-started/views","docs/4.x/1.getting-started/04.views",{"title":39,"path":1141,"stem":1142,"titleTemplate":6,"icon":42},"/docs/4.x/getting-started/assets","docs/4.x/1.getting-started/05.assets",{"title":44,"path":1144,"stem":1145,"titleTemplate":6,"icon":47},"/docs/4.x/getting-started/styling","docs/4.x/1.getting-started/06.styling",{"title":49,"path":1147,"stem":1148,"titleTemplate":6,"icon":52},"/docs/4.x/getting-started/routing","docs/4.x/1.getting-started/07.routing",{"title":54,"path":1150,"stem":1151,"titleTemplate":6,"icon":57},"/docs/4.x/getting-started/seo-meta","docs/4.x/1.getting-started/08.seo-meta",{"title":59,"path":1153,"stem":1154,"titleTemplate":6,"icon":62},"/docs/4.x/getting-started/transitions","docs/4.x/1.getting-started/09.transitions",{"title":64,"path":1156,"stem":1157,"titleTemplate":6,"icon":67},"/docs/4.x/getting-started/data-fetching","docs/4.x/1.getting-started/10.data-fetching",{"title":69,"path":1159,"stem":1160,"titleTemplate":6,"icon":72},"/docs/4.x/getting-started/state-management","docs/4.x/1.getting-started/11.state-management",{"title":74,"path":1162,"stem":1163,"titleTemplate":6,"icon":77},"/docs/4.x/getting-started/error-handling","docs/4.x/1.getting-started/12.error-handling",{"title":79,"path":1165,"stem":1166,"titleTemplate":6,"icon":82},"/docs/4.x/getting-started/server","docs/4.x/1.getting-started/13.server",{"title":84,"path":1168,"stem":1169,"titleTemplate":6,"icon":87},"/docs/4.x/getting-started/layers","docs/4.x/1.getting-started/14.layers",{"title":89,"path":1171,"stem":1172,"titleTemplate":6,"icon":92},"/docs/4.x/getting-started/prerendering","docs/4.x/1.getting-started/15.prerendering",{"title":94,"path":1174,"stem":1175,"titleTemplate":6,"icon":97},"/docs/4.x/getting-started/deployment","docs/4.x/1.getting-started/16.deployment",{"title":99,"path":1177,"stem":1178,"titleTemplate":6,"icon":102},"/docs/4.x/getting-started/testing","docs/4.x/1.getting-started/17.testing",{"title":104,"path":1180,"stem":1181,"titleTemplate":6,"icon":107},"/docs/4.x/getting-started/upgrade","docs/4.x/1.getting-started/18.upgrade",{"title":110,"titleTemplate":111,"icon":112,"path":1183,"stem":1184,"children":1185,"page":108},"/docs/4.x/directory-structure","docs/4.x/2.directory-structure",[1186,1189,1192,1234,1237,1240,1243,1246,1249,1252,1255,1258,1261,1264,1267,1270,1273],{"title":117,"path":1187,"stem":1188,"titleTemplate":6,"icon":120},"/docs/4.x/directory-structure/nuxt","docs/4.x/2.directory-structure/0.nuxt",{"title":122,"path":1190,"stem":1191,"titleTemplate":6,"icon":125},"/docs/4.x/directory-structure/output","docs/4.x/2.directory-structure/0.output",{"title":1193,"titleTemplate":111,"head":1194,"defaultOpen":1196,"icon":1197,"path":1198,"stem":1199,"children":1200,"page":108},"app",{"title":1195},"app/",true,"i-vscode-icons-folder-type-app","/docs/4.x/directory-structure/app","docs/4.x/2.directory-structure/1.app",[1201,1204,1207,1210,1213,1216,1219,1222,1225,1228,1231],{"title":127,"path":1202,"stem":1203,"titleTemplate":6,"icon":130},"/docs/4.x/directory-structure/app/assets","docs/4.x/2.directory-structure/1.app/1.assets",{"title":132,"path":1205,"stem":1206,"titleTemplate":6,"icon":135},"/docs/4.x/directory-structure/app/components","docs/4.x/2.directory-structure/1.app/1.components",{"title":137,"path":1208,"stem":1209,"titleTemplate":6,"icon":140},"/docs/4.x/directory-structure/app/composables","docs/4.x/2.directory-structure/1.app/1.composables",{"title":152,"path":1211,"stem":1212,"titleTemplate":6,"icon":155},"/docs/4.x/directory-structure/app/layouts","docs/4.x/2.directory-structure/1.app/1.layouts",{"title":157,"path":1214,"stem":1215,"titleTemplate":6,"icon":160},"/docs/4.x/directory-structure/app/middleware","docs/4.x/2.directory-structure/1.app/1.middleware",{"title":171,"path":1217,"stem":1218,"titleTemplate":6,"icon":155},"/docs/4.x/directory-structure/app/pages","docs/4.x/2.directory-structure/1.app/1.pages",{"title":175,"path":1220,"stem":1221,"titleTemplate":6,"icon":178},"/docs/4.x/directory-structure/app/plugins","docs/4.x/2.directory-structure/1.app/1.plugins",{"title":195,"path":1223,"stem":1224,"titleTemplate":6,"icon":198},"/docs/4.x/directory-structure/app/utils","docs/4.x/2.directory-structure/1.app/1.utils",{"title":219,"path":1226,"stem":1227,"titleTemplate":6,"icon":222},"/docs/4.x/directory-structure/app/app","docs/4.x/2.directory-structure/1.app/3.app",{"title":224,"path":1229,"stem":1230,"titleTemplate":6,"icon":227},"/docs/4.x/directory-structure/app/app-config","docs/4.x/2.directory-structure/1.app/3.app-config",{"title":229,"path":1232,"stem":1233,"titleTemplate":6,"icon":222},"/docs/4.x/directory-structure/app/error","docs/4.x/2.directory-structure/1.app/3.error",{"title":142,"path":1235,"stem":1236,"titleTemplate":6,"icon":145},"/docs/4.x/directory-structure/content","docs/4.x/2.directory-structure/1.content",{"title":147,"path":1238,"stem":1239,"titleTemplate":6,"icon":150},"/docs/4.x/directory-structure/layers","docs/4.x/2.directory-structure/1.layers",{"title":162,"path":1241,"stem":1242,"titleTemplate":6,"icon":150},"/docs/4.x/directory-structure/modules","docs/4.x/2.directory-structure/1.modules",{"title":166,"path":1244,"stem":1245,"titleTemplate":6,"icon":169},"/docs/4.x/directory-structure/node_modules","docs/4.x/2.directory-structure/1.node_modules",{"title":180,"path":1247,"stem":1248,"titleTemplate":6,"icon":183},"/docs/4.x/directory-structure/public","docs/4.x/2.directory-structure/1.public",{"title":185,"path":1250,"stem":1251,"titleTemplate":6,"icon":188},"/docs/4.x/directory-structure/server","docs/4.x/2.directory-structure/1.server",{"title":190,"path":1253,"stem":1254,"titleTemplate":6,"icon":193},"/docs/4.x/directory-structure/shared","docs/4.x/2.directory-structure/1.shared",{"title":200,"path":1256,"stem":1257,"titleTemplate":6,"icon":203},"/docs/4.x/directory-structure/env","docs/4.x/2.directory-structure/2.env",{"title":205,"path":1259,"stem":1260,"titleTemplate":6,"icon":208},"/docs/4.x/directory-structure/gitignore","docs/4.x/2.directory-structure/2.gitignore",{"title":210,"path":1262,"stem":1263,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxtignore","docs/4.x/2.directory-structure/2.nuxtignore",{"title":215,"path":1265,"stem":1266,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxtrc","docs/4.x/2.directory-structure/2.nuxtrc",{"title":233,"path":1268,"stem":1269,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxt-config","docs/4.x/2.directory-structure/3.nuxt-config",{"title":237,"path":1271,"stem":1272,"titleTemplate":6,"icon":240},"/docs/4.x/directory-structure/package","docs/4.x/2.directory-structure/3.package",{"title":242,"path":1274,"stem":1275,"titleTemplate":6,"icon":245},"/docs/4.x/directory-structure/tsconfig","docs/4.x/2.directory-structure/3.tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":1277,"stem":1278,"children":1279,"page":108},"/docs/4.x/guide","docs/4.x/3.guide",[1280,1305,1319,1329,1354,1370],{"title":253,"titleTemplate":254,"icon":255,"path":1281,"stem":1282,"children":1283,"page":108},"/docs/4.x/guide/concepts","docs/4.x/3.guide/1.concepts",[1284,1287,1290,1293,1296,1299,1302],{"title":260,"path":1285,"stem":1286,"titleTemplate":6},"/docs/4.x/guide/concepts/rendering","docs/4.x/3.guide/1.concepts/1.rendering",{"title":264,"path":1288,"stem":1289,"titleTemplate":6},"/docs/4.x/guide/concepts/nuxt-lifecycle","docs/4.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":1291,"stem":1292,"titleTemplate":6},"/docs/4.x/guide/concepts/auto-imports","docs/4.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":1294,"stem":1295,"titleTemplate":6},"/docs/4.x/guide/concepts/server-engine","docs/4.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":1297,"stem":1298,"titleTemplate":6},"/docs/4.x/guide/concepts/modules","docs/4.x/3.guide/1.concepts/5.modules",{"title":280,"path":1300,"stem":1301,"titleTemplate":6},"/docs/4.x/guide/concepts/typescript","docs/4.x/3.guide/1.concepts/8.typescript",{"title":284,"path":1303,"stem":1304,"titleTemplate":6},"/docs/4.x/guide/concepts/code-style","docs/4.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":1306,"stem":1307,"children":1308,"page":108},"/docs/4.x/guide/best-practices","docs/4.x/3.guide/2.best-practices",[1309,1313,1316],{"title":1310,"path":1311,"stem":1312,"titleTemplate":6},"Nuxt and Hydration","/docs/4.x/guide/best-practices/hydration","docs/4.x/3.guide/2.best-practices/hydration",{"title":299,"path":1314,"stem":1315,"titleTemplate":6},"/docs/4.x/guide/best-practices/performance","docs/4.x/3.guide/2.best-practices/performance",{"title":303,"path":1317,"stem":1318,"titleTemplate":6},"/docs/4.x/guide/best-practices/plugins","docs/4.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":1320,"stem":1321,"children":1322,"page":108},"/docs/4.x/guide/ai","docs/4.x/3.guide/3.ai",[1323,1326],{"title":314,"path":1324,"stem":1325,"titleTemplate":6},"/docs/4.x/guide/ai/mcp","docs/4.x/3.guide/3.ai/1.mcp",{"title":318,"path":1327,"stem":1328,"titleTemplate":6},"/docs/4.x/guide/ai/llms-txt","docs/4.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":1330,"stem":1331,"children":1332,"page":108},"/docs/4.x/guide/modules","docs/4.x/3.guide/4.modules",[1333,1336,1339,1342,1345,1348,1351],{"title":329,"path":1334,"stem":1335,"titleTemplate":6},"/docs/4.x/guide/modules/getting-started","docs/4.x/3.guide/4.modules/1.getting-started",{"title":333,"path":1337,"stem":1338,"titleTemplate":6},"/docs/4.x/guide/modules/module-anatomy","docs/4.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":1340,"stem":1341,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-basics","docs/4.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":1343,"stem":1344,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-advanced","docs/4.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":1346,"stem":1347,"titleTemplate":6},"/docs/4.x/guide/modules/testing","docs/4.x/3.guide/4.modules/5.testing",{"title":349,"path":1349,"stem":1350,"titleTemplate":6},"/docs/4.x/guide/modules/best-practices","docs/4.x/3.guide/4.modules/6.best-practices",{"title":353,"path":1352,"stem":1353,"titleTemplate":6},"/docs/4.x/guide/modules/ecosystem","docs/4.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":1355,"stem":1356,"children":1357,"page":108},"/docs/4.x/guide/recipes","docs/4.x/3.guide/5.recipes",[1358,1361,1364,1367],{"title":364,"path":1359,"stem":1360,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-routing","docs/4.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":1362,"stem":1363,"titleTemplate":6},"/docs/4.x/guide/recipes/vite-plugin","docs/4.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":1365,"stem":1366,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-usefetch","docs/4.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":1368,"stem":1369,"titleTemplate":6},"/docs/4.x/guide/recipes/sessions-and-authentication","docs/4.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":1371,"stem":1372,"children":1373,"page":108},"/docs/4.x/guide/going-further","docs/4.x/3.guide/6.going-further",[1374,1377,1380,1383,1386,1389,1392,1395,1398,1401],{"title":387,"path":1375,"stem":1376,"titleTemplate":6},"/docs/4.x/guide/going-further/events","docs/4.x/3.guide/6.going-further/1.events",{"title":391,"path":1378,"stem":1379,"titleTemplate":6},"/docs/4.x/guide/going-further/experimental-features","docs/4.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":1381,"stem":1382,"titleTemplate":6},"/docs/4.x/guide/going-further/features","docs/4.x/3.guide/6.going-further/1.features",{"title":399,"path":1384,"stem":1385,"titleTemplate":6},"/docs/4.x/guide/going-further/runtime-config","docs/4.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":1387,"stem":1388,"titleTemplate":6},"/docs/4.x/guide/going-further/nightly-release-channel","docs/4.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":1390,"stem":1391,"titleTemplate":6},"/docs/4.x/guide/going-further/hooks","docs/4.x/3.guide/6.going-further/2.hooks",{"title":411,"path":1393,"stem":1394,"titleTemplate":6},"/docs/4.x/guide/going-further/kit","docs/4.x/3.guide/6.going-further/4.kit",{"title":415,"path":1396,"stem":1397,"titleTemplate":6},"/docs/4.x/guide/going-further/nuxt-app","docs/4.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":1399,"stem":1400,"titleTemplate":6},"/docs/4.x/guide/going-further/layers","docs/4.x/3.guide/6.going-further/7.layers",{"title":423,"path":1402,"stem":1403,"titleTemplate":6},"/docs/4.x/guide/going-further/debugging","docs/4.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":1405,"stem":1406,"children":1407,"page":108},"/docs/4.x/api","docs/4.x/4.api",[1408,1461,1556,1647,1699,1757,1767],{"title":434,"titleTemplate":435,"icon":324,"path":1409,"stem":1410,"children":1411,"page":108},"/docs/4.x/api/components","docs/4.x/4.api/1.components",[1412,1415,1418,1421,1424,1427,1430,1433,1437,1440,1443,1446,1449,1452,1455,1458],{"title":440,"path":1413,"stem":1414,"titleTemplate":6},"/docs/4.x/api/components/client-only","docs/4.x/4.api/1.components/1.client-only",{"title":444,"path":1416,"stem":1417,"titleTemplate":6},"/docs/4.x/api/components/dev-only","docs/4.x/4.api/1.components/1.dev-only",{"title":448,"path":1419,"stem":1420,"titleTemplate":6},"/docs/4.x/api/components/nuxt-client-fallback","docs/4.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":1422,"stem":1423,"titleTemplate":6},"/docs/4.x/api/components/nuxt-picture","docs/4.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":1425,"stem":1426,"titleTemplate":6},"/docs/4.x/api/components/teleports","docs/4.x/4.api/1.components/11.teleports",{"title":460,"path":1428,"stem":1429,"titleTemplate":6},"/docs/4.x/api/components/nuxt-route-announcer","docs/4.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":1431,"stem":1432,"titleTemplate":6},"/docs/4.x/api/components/nuxt-time","docs/4.x/4.api/1.components/13.nuxt-time",{"title":1434,"path":1435,"stem":1436,"titleTemplate":6},"\u003CNuxtAnnouncer>","/docs/4.x/api/components/nuxt-announcer","docs/4.x/4.api/1.components/14.nuxt-announcer",{"title":468,"path":1438,"stem":1439,"titleTemplate":6},"/docs/4.x/api/components/nuxt-page","docs/4.x/4.api/1.components/2.nuxt-page",{"title":472,"path":1441,"stem":1442,"titleTemplate":6},"/docs/4.x/api/components/nuxt-layout","docs/4.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":1444,"stem":1445,"titleTemplate":6},"/docs/4.x/api/components/nuxt-link","docs/4.x/4.api/1.components/4.nuxt-link",{"title":480,"path":1447,"stem":1448,"titleTemplate":6},"/docs/4.x/api/components/nuxt-loading-indicator","docs/4.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":1450,"stem":1451,"titleTemplate":6},"/docs/4.x/api/components/nuxt-error-boundary","docs/4.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":1453,"stem":1454,"titleTemplate":6},"/docs/4.x/api/components/nuxt-welcome","docs/4.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":1456,"stem":1457,"titleTemplate":6},"/docs/4.x/api/components/nuxt-island","docs/4.x/4.api/1.components/8.nuxt-island",{"title":496,"path":1459,"stem":1460,"titleTemplate":6},"/docs/4.x/api/components/nuxt-img","docs/4.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":1462,"stem":1463,"children":1464,"page":108},"/docs/4.x/api/composables","docs/4.x/4.api/2.composables",[1465,1468,1472,1475,1478,1481,1484,1487,1490,1493,1496,1499,1502,1505,1508,1511,1514,1517,1520,1523,1526,1529,1532,1535,1538,1541,1544,1547,1550,1553],{"title":507,"path":1466,"stem":1467,"titleTemplate":6},"/docs/4.x/api/composables/on-prehydrate","docs/4.x/4.api/2.composables/on-prehydrate",{"title":1469,"path":1470,"stem":1471,"titleTemplate":6},"useAnnouncer","/docs/4.x/api/composables/use-announcer","docs/4.x/4.api/2.composables/use-announcer",{"title":511,"path":1473,"stem":1474,"titleTemplate":6},"/docs/4.x/api/composables/use-app-config","docs/4.x/4.api/2.composables/use-app-config",{"title":515,"path":1476,"stem":1477,"titleTemplate":6},"/docs/4.x/api/composables/use-async-data","docs/4.x/4.api/2.composables/use-async-data",{"title":519,"path":1479,"stem":1480,"titleTemplate":6},"/docs/4.x/api/composables/use-cookie","docs/4.x/4.api/2.composables/use-cookie",{"title":523,"path":1482,"stem":1483,"titleTemplate":6},"/docs/4.x/api/composables/use-error","docs/4.x/4.api/2.composables/use-error",{"title":527,"path":1485,"stem":1486,"titleTemplate":6},"/docs/4.x/api/composables/use-fetch","docs/4.x/4.api/2.composables/use-fetch",{"title":531,"path":1488,"stem":1489,"titleTemplate":6},"/docs/4.x/api/composables/use-head","docs/4.x/4.api/2.composables/use-head",{"title":535,"path":1491,"stem":1492,"titleTemplate":6},"/docs/4.x/api/composables/use-head-safe","docs/4.x/4.api/2.composables/use-head-safe",{"title":539,"path":1494,"stem":1495,"titleTemplate":6},"/docs/4.x/api/composables/use-hydration","docs/4.x/4.api/2.composables/use-hydration",{"title":543,"path":1497,"stem":1498,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-async-data","docs/4.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":1500,"stem":1501,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-fetch","docs/4.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":1503,"stem":1504,"titleTemplate":6},"/docs/4.x/api/composables/use-loading-indicator","docs/4.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":1506,"stem":1507,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-app","docs/4.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":1509,"stem":1510,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-data","docs/4.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":1512,"stem":1513,"titleTemplate":6},"/docs/4.x/api/composables/use-preview-mode","docs/4.x/4.api/2.composables/use-preview-mode",{"title":567,"path":1515,"stem":1516,"titleTemplate":6},"/docs/4.x/api/composables/use-request-event","docs/4.x/4.api/2.composables/use-request-event",{"title":571,"path":1518,"stem":1519,"titleTemplate":6},"/docs/4.x/api/composables/use-request-fetch","docs/4.x/4.api/2.composables/use-request-fetch",{"title":575,"path":1521,"stem":1522,"titleTemplate":6},"/docs/4.x/api/composables/use-request-header","docs/4.x/4.api/2.composables/use-request-header",{"title":579,"path":1524,"stem":1525,"titleTemplate":6},"/docs/4.x/api/composables/use-request-headers","docs/4.x/4.api/2.composables/use-request-headers",{"title":583,"path":1527,"stem":1528,"titleTemplate":6},"/docs/4.x/api/composables/use-request-url","docs/4.x/4.api/2.composables/use-request-url",{"title":587,"path":1530,"stem":1531,"titleTemplate":6},"/docs/4.x/api/composables/use-response-header","docs/4.x/4.api/2.composables/use-response-header",{"title":591,"path":1533,"stem":1534,"titleTemplate":6},"/docs/4.x/api/composables/use-route","docs/4.x/4.api/2.composables/use-route",{"title":595,"path":1536,"stem":1537,"titleTemplate":6},"/docs/4.x/api/composables/use-route-announcer","docs/4.x/4.api/2.composables/use-route-announcer",{"title":599,"path":1539,"stem":1540,"titleTemplate":6},"/docs/4.x/api/composables/use-router","docs/4.x/4.api/2.composables/use-router",{"title":603,"path":1542,"stem":1543,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-config","docs/4.x/4.api/2.composables/use-runtime-config",{"title":607,"path":1545,"stem":1546,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-hook","docs/4.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":1548,"stem":1549,"titleTemplate":6},"/docs/4.x/api/composables/use-seo-meta","docs/4.x/4.api/2.composables/use-seo-meta",{"title":615,"path":1551,"stem":1552,"titleTemplate":6},"/docs/4.x/api/composables/use-server-seo-meta","docs/4.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":1554,"stem":1555,"titleTemplate":6},"/docs/4.x/api/composables/use-state","docs/4.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":1557,"stem":1558,"children":1559,"page":108},"/docs/4.x/api/utils","docs/4.x/4.api/3.utils",[1560,1563,1566,1569,1572,1575,1578,1581,1584,1587,1590,1593,1596,1599,1602,1605,1608,1611,1614,1617,1620,1623,1626,1629,1632,1635,1638,1641,1644],{"title":630,"path":1561,"stem":1562,"titleTemplate":6},"/docs/4.x/api/utils/dollarfetch","docs/4.x/4.api/3.utils/$fetch",{"title":634,"path":1564,"stem":1565,"titleTemplate":6},"/docs/4.x/api/utils/abort-navigation","docs/4.x/4.api/3.utils/abort-navigation",{"title":638,"path":1567,"stem":1568,"titleTemplate":6},"/docs/4.x/api/utils/add-route-middleware","docs/4.x/4.api/3.utils/add-route-middleware",{"title":642,"path":1570,"stem":1571,"titleTemplate":6},"/docs/4.x/api/utils/call-once","docs/4.x/4.api/3.utils/call-once",{"title":646,"path":1573,"stem":1574,"titleTemplate":6},"/docs/4.x/api/utils/clear-error","docs/4.x/4.api/3.utils/clear-error",{"title":650,"path":1576,"stem":1577,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-data","docs/4.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":1579,"stem":1580,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-state","docs/4.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":1582,"stem":1583,"titleTemplate":6},"/docs/4.x/api/utils/create-error","docs/4.x/4.api/3.utils/create-error",{"title":662,"path":1585,"stem":1586,"titleTemplate":6},"/docs/4.x/api/utils/define-lazy-hydration-component","docs/4.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":1588,"stem":1589,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-component","docs/4.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":1591,"stem":1592,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-plugin","docs/4.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":1594,"stem":1595,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-route-middleware","docs/4.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":1597,"stem":1598,"titleTemplate":6},"/docs/4.x/api/utils/define-page-meta","docs/4.x/4.api/3.utils/define-page-meta",{"title":682,"path":1600,"stem":1601,"titleTemplate":6},"/docs/4.x/api/utils/define-route-rules","docs/4.x/4.api/3.utils/define-route-rules",{"title":686,"path":1603,"stem":1604,"titleTemplate":6},"/docs/4.x/api/utils/navigate-to","docs/4.x/4.api/3.utils/navigate-to",{"title":690,"path":1606,"stem":1607,"titleTemplate":6},"/docs/4.x/api/utils/on-before-route-leave","docs/4.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":1609,"stem":1610,"titleTemplate":6},"/docs/4.x/api/utils/on-before-route-update","docs/4.x/4.api/3.utils/on-before-route-update",{"title":698,"path":1612,"stem":1613,"titleTemplate":6},"/docs/4.x/api/utils/on-nuxt-ready","docs/4.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":1615,"stem":1616,"titleTemplate":6},"/docs/4.x/api/utils/prefetch-components","docs/4.x/4.api/3.utils/prefetch-components",{"title":706,"path":1618,"stem":1619,"titleTemplate":6},"/docs/4.x/api/utils/preload-components","docs/4.x/4.api/3.utils/preload-components",{"title":710,"path":1621,"stem":1622,"titleTemplate":6},"/docs/4.x/api/utils/preload-route-components","docs/4.x/4.api/3.utils/preload-route-components",{"title":714,"path":1624,"stem":1625,"titleTemplate":6},"/docs/4.x/api/utils/prerender-routes","docs/4.x/4.api/3.utils/prerender-routes",{"title":718,"path":1627,"stem":1628,"titleTemplate":6},"/docs/4.x/api/utils/refresh-cookie","docs/4.x/4.api/3.utils/refresh-cookie",{"title":722,"path":1630,"stem":1631,"titleTemplate":6},"/docs/4.x/api/utils/refresh-nuxt-data","docs/4.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":1633,"stem":1634,"titleTemplate":6},"/docs/4.x/api/utils/reload-nuxt-app","docs/4.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":1636,"stem":1637,"titleTemplate":6},"/docs/4.x/api/utils/set-page-layout","docs/4.x/4.api/3.utils/set-page-layout",{"title":734,"path":1639,"stem":1640,"titleTemplate":6},"/docs/4.x/api/utils/set-response-status","docs/4.x/4.api/3.utils/set-response-status",{"title":738,"path":1642,"stem":1643,"titleTemplate":6},"/docs/4.x/api/utils/show-error","docs/4.x/4.api/3.utils/show-error",{"title":742,"path":1645,"stem":1646,"titleTemplate":6},"/docs/4.x/api/utils/update-app-config","docs/4.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":1648,"stem":1649,"children":1650,"page":108},"/docs/4.x/api/commands","docs/4.x/4.api/4.commands",[1651,1654,1657,1660,1663,1666,1669,1672,1675,1678,1681,1684,1687,1690,1693,1696],{"title":753,"path":1652,"stem":1653,"titleTemplate":6},"/docs/4.x/api/commands/add","docs/4.x/4.api/4.commands/add",{"title":757,"path":1655,"stem":1656,"titleTemplate":6},"/docs/4.x/api/commands/analyze","docs/4.x/4.api/4.commands/analyze",{"title":761,"path":1658,"stem":1659,"titleTemplate":6},"/docs/4.x/api/commands/build","docs/4.x/4.api/4.commands/build",{"title":765,"path":1661,"stem":1662,"titleTemplate":6},"/docs/4.x/api/commands/build-module","docs/4.x/4.api/4.commands/build-module",{"title":769,"path":1664,"stem":1665,"titleTemplate":6},"/docs/4.x/api/commands/cleanup","docs/4.x/4.api/4.commands/cleanup",{"title":773,"path":1667,"stem":1668,"titleTemplate":6},"/docs/4.x/api/commands/dev","docs/4.x/4.api/4.commands/dev",{"title":777,"path":1670,"stem":1671,"titleTemplate":6},"/docs/4.x/api/commands/devtools","docs/4.x/4.api/4.commands/devtools",{"title":781,"path":1673,"stem":1674,"titleTemplate":6},"/docs/4.x/api/commands/generate","docs/4.x/4.api/4.commands/generate",{"title":785,"path":1676,"stem":1677,"titleTemplate":6},"/docs/4.x/api/commands/info","docs/4.x/4.api/4.commands/info",{"title":789,"path":1679,"stem":1680,"titleTemplate":6},"/docs/4.x/api/commands/init","docs/4.x/4.api/4.commands/init",{"title":793,"path":1682,"stem":1683,"titleTemplate":6},"/docs/4.x/api/commands/module","docs/4.x/4.api/4.commands/module",{"title":797,"path":1685,"stem":1686,"titleTemplate":6},"/docs/4.x/api/commands/prepare","docs/4.x/4.api/4.commands/prepare",{"title":801,"path":1688,"stem":1689,"titleTemplate":6},"/docs/4.x/api/commands/preview","docs/4.x/4.api/4.commands/preview",{"title":805,"path":1691,"stem":1692,"titleTemplate":6},"/docs/4.x/api/commands/test","docs/4.x/4.api/4.commands/test",{"title":809,"path":1694,"stem":1695,"titleTemplate":6},"/docs/4.x/api/commands/typecheck","docs/4.x/4.api/4.commands/typecheck",{"title":813,"path":1697,"stem":1698,"titleTemplate":6},"/docs/4.x/api/commands/upgrade","docs/4.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":1700,"stem":1701,"children":1702,"page":108},"/docs/4.x/api/kit","docs/4.x/4.api/5.kit",[1703,1706,1709,1712,1715,1718,1721,1724,1727,1730,1733,1736,1739,1742,1745,1748,1751,1754],{"title":276,"path":1704,"stem":1705,"titleTemplate":6},"/docs/4.x/api/kit/modules","docs/4.x/4.api/5.kit/1.modules",{"title":399,"path":1707,"stem":1708,"titleTemplate":6},"/docs/4.x/api/kit/runtime-config","docs/4.x/4.api/5.kit/10.runtime-config",{"title":829,"path":1710,"stem":1711,"titleTemplate":6},"/docs/4.x/api/kit/templates","docs/4.x/4.api/5.kit/10.templates",{"title":833,"path":1713,"stem":1714,"titleTemplate":6},"/docs/4.x/api/kit/nitro","docs/4.x/4.api/5.kit/11.nitro",{"title":837,"path":1716,"stem":1717,"titleTemplate":6},"/docs/4.x/api/kit/resolving","docs/4.x/4.api/5.kit/12.resolving",{"title":841,"path":1719,"stem":1720,"titleTemplate":6},"/docs/4.x/api/kit/logging","docs/4.x/4.api/5.kit/13.logging",{"title":845,"path":1722,"stem":1723,"titleTemplate":6},"/docs/4.x/api/kit/builder","docs/4.x/4.api/5.kit/14.builder",{"title":849,"path":1725,"stem":1726,"titleTemplate":6},"/docs/4.x/api/kit/examples","docs/4.x/4.api/5.kit/15.examples",{"title":84,"path":1728,"stem":1729,"titleTemplate":6},"/docs/4.x/api/kit/layers","docs/4.x/4.api/5.kit/16.layers",{"title":856,"path":1731,"stem":1732,"titleTemplate":6},"/docs/4.x/api/kit/programmatic","docs/4.x/4.api/5.kit/2.programmatic",{"title":860,"path":1734,"stem":1735,"titleTemplate":6},"/docs/4.x/api/kit/compatibility","docs/4.x/4.api/5.kit/3.compatibility",{"title":268,"path":1737,"stem":1738,"titleTemplate":6},"/docs/4.x/api/kit/autoimports","docs/4.x/4.api/5.kit/4.autoimports",{"title":434,"path":1740,"stem":1741,"titleTemplate":6},"/docs/4.x/api/kit/components","docs/4.x/4.api/5.kit/5.components",{"title":870,"path":1743,"stem":1744,"titleTemplate":6},"/docs/4.x/api/kit/context","docs/4.x/4.api/5.kit/6.context",{"title":874,"path":1746,"stem":1747,"titleTemplate":6},"/docs/4.x/api/kit/pages","docs/4.x/4.api/5.kit/7.pages",{"title":878,"path":1749,"stem":1750,"titleTemplate":6},"/docs/4.x/api/kit/layout","docs/4.x/4.api/5.kit/8.layout",{"title":882,"path":1752,"stem":1753,"titleTemplate":6},"/docs/4.x/api/kit/head","docs/4.x/4.api/5.kit/9.head",{"title":886,"path":1755,"stem":1756,"titleTemplate":6},"/docs/4.x/api/kit/plugins","docs/4.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":1758,"stem":1759,"children":1760,"page":108},"/docs/4.x/api/advanced","docs/4.x/4.api/6.advanced",[1761,1764],{"title":407,"path":1762,"stem":1763,"titleTemplate":6},"/docs/4.x/api/advanced/hooks","docs/4.x/4.api/6.advanced/1.hooks",{"title":899,"path":1765,"stem":1766,"titleTemplate":6},"/docs/4.x/api/advanced/import-meta","docs/4.x/4.api/6.advanced/2.import-meta",{"title":903,"path":1768,"stem":1769,"titleTemplate":906,"icon":32},"/docs/4.x/api/nuxt-config","docs/4.x/4.api/6.nuxt-config",{"title":849,"titleTemplate":908,"icon":909,"path":1771,"stem":1772,"children":1773,"page":108},"/docs/4.x/examples","docs/4.x/4.examples",[1774,1777,1796,1809,1840],{"title":914,"path":1775,"stem":1776,"titleTemplate":6},"/docs/4.x/examples/hello-world","docs/4.x/4.examples/0.hello-world",{"title":395,"path":1778,"stem":1779,"children":1780,"page":108},"/docs/4.x/examples/features","docs/4.x/4.examples/1.features",[1781,1784,1787,1790,1793],{"title":922,"path":1782,"stem":1783,"titleTemplate":6},"/docs/4.x/examples/features/auto-imports","docs/4.x/4.examples/1.features/1.auto-imports",{"title":64,"path":1785,"stem":1786,"titleTemplate":6},"/docs/4.x/examples/features/data-fetching","docs/4.x/4.examples/1.features/2.data-fetching",{"title":69,"path":1788,"stem":1789,"titleTemplate":6},"/docs/4.x/examples/features/state-management","docs/4.x/4.examples/1.features/3.state-management",{"title":932,"path":1791,"stem":1792,"titleTemplate":6},"/docs/4.x/examples/features/meta-tags","docs/4.x/4.examples/1.features/4.meta-tags",{"title":936,"path":1794,"stem":1795,"titleTemplate":6},"/docs/4.x/examples/features/layouts","docs/4.x/4.examples/1.features/5.layouts",{"title":49,"path":1797,"stem":1798,"children":1799,"page":108},"/docs/4.x/examples/routing","docs/4.x/4.examples/2.routing",[1800,1803,1806],{"title":944,"path":1801,"stem":1802,"titleTemplate":6},"/docs/4.x/examples/routing/middleware","docs/4.x/4.examples/2.routing/middleware",{"title":874,"path":1804,"stem":1805,"titleTemplate":6},"/docs/4.x/examples/routing/pages","docs/4.x/4.examples/2.routing/pages",{"title":951,"path":1807,"stem":1808,"titleTemplate":6},"/docs/4.x/examples/routing/universal-router","docs/4.x/4.examples/2.routing/universal-router",{"title":890,"path":1810,"stem":1811,"children":1812,"page":108},"/docs/4.x/examples/advanced","docs/4.x/4.examples/4.advanced",[1813,1816,1819,1822,1825,1828,1831,1834,1837],{"title":84,"path":1814,"stem":1815,"titleTemplate":6},"/docs/4.x/examples/advanced/config-extends","docs/4.x/4.examples/4.advanced/config-extends",{"title":74,"path":1817,"stem":1818,"titleTemplate":6},"/docs/4.x/examples/advanced/error-handling","docs/4.x/4.examples/4.advanced/error-handling",{"title":965,"path":1820,"stem":1821,"titleTemplate":6},"/docs/4.x/examples/advanced/jsx","docs/4.x/4.examples/4.advanced/jsx",{"title":969,"path":1823,"stem":1824,"titleTemplate":6},"/docs/4.x/examples/advanced/locale","docs/4.x/4.examples/4.advanced/locale",{"title":973,"path":1826,"stem":1827,"titleTemplate":6},"/docs/4.x/examples/advanced/module-extend-pages","docs/4.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":1829,"stem":1830,"titleTemplate":6},"/docs/4.x/examples/advanced/teleport","docs/4.x/4.examples/4.advanced/teleport",{"title":99,"path":1832,"stem":1833,"titleTemplate":6},"/docs/4.x/examples/advanced/testing","docs/4.x/4.examples/4.advanced/testing",{"title":519,"path":1835,"stem":1836,"titleTemplate":6},"/docs/4.x/examples/advanced/use-cookie","docs/4.x/4.examples/4.advanced/use-cookie",{"title":987,"path":1838,"stem":1839,"titleTemplate":6},"/docs/4.x/examples/advanced/use-custom-fetch-composable","docs/4.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":1841,"stem":1842,"children":1843,"page":108},"/docs/4.x/examples/experimental","docs/4.x/4.examples/7.experimental",[1844],{"title":996,"path":1845,"stem":1846,"titleTemplate":6},"/docs/4.x/examples/experimental/wasm","docs/4.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1848,"stem":1849,"children":1850,"page":108},"/docs/4.x/community","docs/4.x/5.community",[1851,1854,1857,1860,1863,1866],{"title":1007,"path":1852,"stem":1853,"titleTemplate":6,"icon":1010},"/docs/4.x/community/getting-help","docs/4.x/5.community/2.getting-help",{"title":1012,"path":1855,"stem":1856,"titleTemplate":6,"icon":1015},"/docs/4.x/community/reporting-bugs","docs/4.x/5.community/3.reporting-bugs",{"title":1017,"path":1858,"stem":1859,"titleTemplate":6,"icon":1020},"/docs/4.x/community/contribution","docs/4.x/5.community/4.contribution",{"title":1022,"path":1861,"stem":1862,"titleTemplate":6,"icon":1025},"/docs/4.x/community/framework-contribution","docs/4.x/5.community/5.framework-contribution",{"title":1027,"path":1864,"stem":1865,"titleTemplate":6,"icon":1030},"/docs/4.x/community/roadmap","docs/4.x/5.community/6.roadmap",{"title":1032,"path":1867,"stem":1868,"titleTemplate":6,"icon":1035},"/docs/4.x/community/changelog","docs/4.x/5.community/7.changelog",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1870,"stem":1871,"children":1872,"page":108},"/docs/4.x/bridge","docs/4.x/6.bridge",[1873,1876,1879,1882,1885,1888,1891,1894,1897,1900],{"title":1044,"path":1874,"stem":1875,"titleTemplate":6},"/docs/4.x/bridge/overview","docs/4.x/6.bridge/1.overview",{"title":29,"path":1877,"stem":1878,"titleTemplate":6},"/docs/4.x/bridge/configuration","docs/4.x/6.bridge/10.configuration",{"title":280,"path":1880,"stem":1881,"titleTemplate":6},"/docs/4.x/bridge/typescript","docs/4.x/6.bridge/2.typescript",{"title":1054,"path":1883,"stem":1884,"titleTemplate":6},"/docs/4.x/bridge/bridge-composition-api","docs/4.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1886,"stem":1887,"titleTemplate":6},"/docs/4.x/bridge/plugins-and-middleware","docs/4.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1889,"stem":1890,"titleTemplate":6},"/docs/4.x/bridge/nuxt3-compatible-api","docs/4.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1892,"stem":1893,"titleTemplate":6},"/docs/4.x/bridge/meta","docs/4.x/6.bridge/6.meta",{"title":399,"path":1895,"stem":1896,"titleTemplate":6},"/docs/4.x/bridge/runtime-config","docs/4.x/6.bridge/7.runtime-config",{"title":833,"path":1898,"stem":1899,"titleTemplate":6},"/docs/4.x/bridge/nitro","docs/4.x/6.bridge/8.nitro",{"title":1075,"path":1901,"stem":1902,"titleTemplate":6},"/docs/4.x/bridge/vite","docs/4.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1904,"stem":1905,"children":1906,"page":108},"/docs/4.x/migration","docs/4.x/7.migration",[1907,1910,1913,1916,1919,1922,1925,1928,1931,1934,1937],{"title":1044,"path":1908,"stem":1909,"titleTemplate":6},"/docs/4.x/migration/overview","docs/4.x/7.migration/1.overview",{"title":1088,"path":1911,"stem":1912,"titleTemplate":6},"/docs/4.x/migration/bundling","docs/4.x/7.migration/10.bundling",{"title":79,"path":1914,"stem":1915,"titleTemplate":6},"/docs/4.x/migration/server","docs/4.x/7.migration/11.server",{"title":29,"path":1917,"stem":1918,"titleTemplate":6},"/docs/4.x/migration/configuration","docs/4.x/7.migration/2.configuration",{"title":276,"path":1920,"stem":1921,"titleTemplate":6},"/docs/4.x/migration/module-authors","docs/4.x/7.migration/20.module-authors",{"title":922,"path":1923,"stem":1924,"titleTemplate":6},"/docs/4.x/migration/auto-imports","docs/4.x/7.migration/3.auto-imports",{"title":932,"path":1926,"stem":1927,"titleTemplate":6},"/docs/4.x/migration/meta","docs/4.x/7.migration/4.meta",{"title":1058,"path":1929,"stem":1930,"titleTemplate":6},"/docs/4.x/migration/plugins-and-middleware","docs/4.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1932,"stem":1933,"titleTemplate":6},"/docs/4.x/migration/pages-and-layouts","docs/4.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1935,"stem":1936,"titleTemplate":6},"/docs/4.x/migration/component-options","docs/4.x/7.migration/7.component-options",{"title":399,"path":1938,"stem":1939,"titleTemplate":6},"/docs/4.x/migration/runtime-config","docs/4.x/7.migration/8.runtime-config",{"title":5,"titleTemplate":6,"icon":7,"path":1941,"stem":1942,"children":1943,"page":108},"/docs/5.x","docs/5.x",[1944,2002,2092,2219,2583,2660,2682,2716],{"title":12,"titleTemplate":13,"icon":14,"path":1945,"stem":1946,"children":1947,"page":108},"/docs/5.x/getting-started","docs/5.x/1.getting-started",[1948,1951,1954,1957,1960,1963,1966,1969,1972,1975,1978,1981,1984,1987,1990,1993,1996,1999],{"title":19,"path":1949,"stem":1950,"titleTemplate":6,"icon":22},"/docs/5.x/getting-started/introduction","docs/5.x/1.getting-started/01.introduction",{"title":24,"path":1952,"stem":1953,"titleTemplate":6,"icon":27},"/docs/5.x/getting-started/installation","docs/5.x/1.getting-started/02.installation",{"title":29,"path":1955,"stem":1956,"titleTemplate":6,"icon":32},"/docs/5.x/getting-started/configuration","docs/5.x/1.getting-started/03.configuration",{"title":34,"path":1958,"stem":1959,"titleTemplate":6,"icon":37},"/docs/5.x/getting-started/views","docs/5.x/1.getting-started/04.views",{"title":39,"path":1961,"stem":1962,"titleTemplate":6,"icon":42},"/docs/5.x/getting-started/assets","docs/5.x/1.getting-started/05.assets",{"title":44,"path":1964,"stem":1965,"titleTemplate":6,"icon":47},"/docs/5.x/getting-started/styling","docs/5.x/1.getting-started/06.styling",{"title":49,"path":1967,"stem":1968,"titleTemplate":6,"icon":52},"/docs/5.x/getting-started/routing","docs/5.x/1.getting-started/07.routing",{"title":54,"path":1970,"stem":1971,"titleTemplate":6,"icon":57},"/docs/5.x/getting-started/seo-meta","docs/5.x/1.getting-started/08.seo-meta",{"title":59,"path":1973,"stem":1974,"titleTemplate":6,"icon":62},"/docs/5.x/getting-started/transitions","docs/5.x/1.getting-started/09.transitions",{"title":64,"path":1976,"stem":1977,"titleTemplate":6,"icon":67},"/docs/5.x/getting-started/data-fetching","docs/5.x/1.getting-started/10.data-fetching",{"title":69,"path":1979,"stem":1980,"titleTemplate":6,"icon":72},"/docs/5.x/getting-started/state-management","docs/5.x/1.getting-started/11.state-management",{"title":74,"path":1982,"stem":1983,"titleTemplate":6,"icon":77},"/docs/5.x/getting-started/error-handling","docs/5.x/1.getting-started/12.error-handling",{"title":79,"path":1985,"stem":1986,"titleTemplate":6,"icon":82},"/docs/5.x/getting-started/server","docs/5.x/1.getting-started/13.server",{"title":84,"path":1988,"stem":1989,"titleTemplate":6,"icon":87},"/docs/5.x/getting-started/layers","docs/5.x/1.getting-started/14.layers",{"title":89,"path":1991,"stem":1992,"titleTemplate":6,"icon":92},"/docs/5.x/getting-started/prerendering","docs/5.x/1.getting-started/15.prerendering",{"title":94,"path":1994,"stem":1995,"titleTemplate":6,"icon":97},"/docs/5.x/getting-started/deployment","docs/5.x/1.getting-started/16.deployment",{"title":99,"path":1997,"stem":1998,"titleTemplate":6,"icon":102},"/docs/5.x/getting-started/testing","docs/5.x/1.getting-started/17.testing",{"title":104,"path":2000,"stem":2001,"titleTemplate":6,"icon":107},"/docs/5.x/getting-started/upgrade","docs/5.x/1.getting-started/18.upgrade",{"title":110,"titleTemplate":111,"icon":112,"path":2003,"stem":2004,"children":2005,"page":108},"/docs/5.x/directory-structure","docs/5.x/2.directory-structure",[2006,2009,2012,2050,2053,2056,2059,2062,2065,2068,2071,2074,2077,2080,2083,2086,2089],{"title":117,"path":2007,"stem":2008,"titleTemplate":6,"icon":120},"/docs/5.x/directory-structure/nuxt","docs/5.x/2.directory-structure/0.nuxt",{"title":122,"path":2010,"stem":2011,"titleTemplate":6,"icon":125},"/docs/5.x/directory-structure/output","docs/5.x/2.directory-structure/0.output",{"title":1193,"titleTemplate":111,"head":2013,"defaultOpen":1196,"icon":1197,"path":2014,"stem":2015,"children":2016,"page":108},{"title":1195},"/docs/5.x/directory-structure/app","docs/5.x/2.directory-structure/1.app",[2017,2020,2023,2026,2029,2032,2035,2038,2041,2044,2047],{"title":127,"path":2018,"stem":2019,"titleTemplate":6,"icon":130},"/docs/5.x/directory-structure/app/assets","docs/5.x/2.directory-structure/1.app/1.assets",{"title":132,"path":2021,"stem":2022,"titleTemplate":6,"icon":135},"/docs/5.x/directory-structure/app/components","docs/5.x/2.directory-structure/1.app/1.components",{"title":137,"path":2024,"stem":2025,"titleTemplate":6,"icon":140},"/docs/5.x/directory-structure/app/composables","docs/5.x/2.directory-structure/1.app/1.composables",{"title":152,"path":2027,"stem":2028,"titleTemplate":6,"icon":155},"/docs/5.x/directory-structure/app/layouts","docs/5.x/2.directory-structure/1.app/1.layouts",{"title":157,"path":2030,"stem":2031,"titleTemplate":6,"icon":160},"/docs/5.x/directory-structure/app/middleware","docs/5.x/2.directory-structure/1.app/1.middleware",{"title":171,"path":2033,"stem":2034,"titleTemplate":6,"icon":155},"/docs/5.x/directory-structure/app/pages","docs/5.x/2.directory-structure/1.app/1.pages",{"title":175,"path":2036,"stem":2037,"titleTemplate":6,"icon":178},"/docs/5.x/directory-structure/app/plugins","docs/5.x/2.directory-structure/1.app/1.plugins",{"title":195,"path":2039,"stem":2040,"titleTemplate":6,"icon":198},"/docs/5.x/directory-structure/app/utils","docs/5.x/2.directory-structure/1.app/1.utils",{"title":219,"path":2042,"stem":2043,"titleTemplate":6,"icon":222},"/docs/5.x/directory-structure/app/app","docs/5.x/2.directory-structure/1.app/3.app",{"title":224,"path":2045,"stem":2046,"titleTemplate":6,"icon":227},"/docs/5.x/directory-structure/app/app-config","docs/5.x/2.directory-structure/1.app/3.app-config",{"title":229,"path":2048,"stem":2049,"titleTemplate":6,"icon":222},"/docs/5.x/directory-structure/app/error","docs/5.x/2.directory-structure/1.app/3.error",{"title":142,"path":2051,"stem":2052,"titleTemplate":6,"icon":145},"/docs/5.x/directory-structure/content","docs/5.x/2.directory-structure/1.content",{"title":147,"path":2054,"stem":2055,"titleTemplate":6,"icon":150},"/docs/5.x/directory-structure/layers","docs/5.x/2.directory-structure/1.layers",{"title":162,"path":2057,"stem":2058,"titleTemplate":6,"icon":150},"/docs/5.x/directory-structure/modules","docs/5.x/2.directory-structure/1.modules",{"title":166,"path":2060,"stem":2061,"titleTemplate":6,"icon":169},"/docs/5.x/directory-structure/node_modules","docs/5.x/2.directory-structure/1.node_modules",{"title":180,"path":2063,"stem":2064,"titleTemplate":6,"icon":183},"/docs/5.x/directory-structure/public","docs/5.x/2.directory-structure/1.public",{"title":185,"path":2066,"stem":2067,"titleTemplate":6,"icon":188},"/docs/5.x/directory-structure/server","docs/5.x/2.directory-structure/1.server",{"title":190,"path":2069,"stem":2070,"titleTemplate":6,"icon":193},"/docs/5.x/directory-structure/shared","docs/5.x/2.directory-structure/1.shared",{"title":200,"path":2072,"stem":2073,"titleTemplate":6,"icon":203},"/docs/5.x/directory-structure/env","docs/5.x/2.directory-structure/2.env",{"title":205,"path":2075,"stem":2076,"titleTemplate":6,"icon":208},"/docs/5.x/directory-structure/gitignore","docs/5.x/2.directory-structure/2.gitignore",{"title":210,"path":2078,"stem":2079,"titleTemplate":6,"icon":213},"/docs/5.x/directory-structure/nuxtignore","docs/5.x/2.directory-structure/2.nuxtignore",{"title":215,"path":2081,"stem":2082,"titleTemplate":6,"icon":213},"/docs/5.x/directory-structure/nuxtrc","docs/5.x/2.directory-structure/2.nuxtrc",{"title":233,"path":2084,"stem":2085,"titleTemplate":6,"icon":213},"/docs/5.x/directory-structure/nuxt-config","docs/5.x/2.directory-structure/3.nuxt-config",{"title":237,"path":2087,"stem":2088,"titleTemplate":6,"icon":240},"/docs/5.x/directory-structure/package","docs/5.x/2.directory-structure/3.package",{"title":242,"path":2090,"stem":2091,"titleTemplate":6,"icon":245},"/docs/5.x/directory-structure/tsconfig","docs/5.x/2.directory-structure/3.tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":2093,"stem":2094,"children":2095,"page":108},"/docs/5.x/guide","docs/5.x/3.guide",[2096,2121,2134,2144,2169,2185],{"title":253,"titleTemplate":254,"icon":255,"path":2097,"stem":2098,"children":2099,"page":108},"/docs/5.x/guide/concepts","docs/5.x/3.guide/1.concepts",[2100,2103,2106,2109,2112,2115,2118],{"title":260,"path":2101,"stem":2102,"titleTemplate":6},"/docs/5.x/guide/concepts/rendering","docs/5.x/3.guide/1.concepts/1.rendering",{"title":264,"path":2104,"stem":2105,"titleTemplate":6},"/docs/5.x/guide/concepts/nuxt-lifecycle","docs/5.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":2107,"stem":2108,"titleTemplate":6},"/docs/5.x/guide/concepts/auto-imports","docs/5.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":2110,"stem":2111,"titleTemplate":6},"/docs/5.x/guide/concepts/server-engine","docs/5.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":2113,"stem":2114,"titleTemplate":6},"/docs/5.x/guide/concepts/modules","docs/5.x/3.guide/1.concepts/5.modules",{"title":280,"path":2116,"stem":2117,"titleTemplate":6},"/docs/5.x/guide/concepts/typescript","docs/5.x/3.guide/1.concepts/8.typescript",{"title":284,"path":2119,"stem":2120,"titleTemplate":6},"/docs/5.x/guide/concepts/code-style","docs/5.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":2122,"stem":2123,"children":2124,"page":108},"/docs/5.x/guide/best-practices","docs/5.x/3.guide/2.best-practices",[2125,2128,2131],{"title":1310,"path":2126,"stem":2127,"titleTemplate":6},"/docs/5.x/guide/best-practices/hydration","docs/5.x/3.guide/2.best-practices/hydration",{"title":299,"path":2129,"stem":2130,"titleTemplate":6},"/docs/5.x/guide/best-practices/performance","docs/5.x/3.guide/2.best-practices/performance",{"title":303,"path":2132,"stem":2133,"titleTemplate":6},"/docs/5.x/guide/best-practices/plugins","docs/5.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":2135,"stem":2136,"children":2137,"page":108},"/docs/5.x/guide/ai","docs/5.x/3.guide/3.ai",[2138,2141],{"title":314,"path":2139,"stem":2140,"titleTemplate":6},"/docs/5.x/guide/ai/mcp","docs/5.x/3.guide/3.ai/1.mcp",{"title":318,"path":2142,"stem":2143,"titleTemplate":6},"/docs/5.x/guide/ai/llms-txt","docs/5.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":2145,"stem":2146,"children":2147,"page":108},"/docs/5.x/guide/modules","docs/5.x/3.guide/4.modules",[2148,2151,2154,2157,2160,2163,2166],{"title":329,"path":2149,"stem":2150,"titleTemplate":6},"/docs/5.x/guide/modules/getting-started","docs/5.x/3.guide/4.modules/1.getting-started",{"title":333,"path":2152,"stem":2153,"titleTemplate":6},"/docs/5.x/guide/modules/module-anatomy","docs/5.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":2155,"stem":2156,"titleTemplate":6},"/docs/5.x/guide/modules/recipes-basics","docs/5.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":2158,"stem":2159,"titleTemplate":6},"/docs/5.x/guide/modules/recipes-advanced","docs/5.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":2161,"stem":2162,"titleTemplate":6},"/docs/5.x/guide/modules/testing","docs/5.x/3.guide/4.modules/5.testing",{"title":349,"path":2164,"stem":2165,"titleTemplate":6},"/docs/5.x/guide/modules/best-practices","docs/5.x/3.guide/4.modules/6.best-practices",{"title":353,"path":2167,"stem":2168,"titleTemplate":6},"/docs/5.x/guide/modules/ecosystem","docs/5.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":2170,"stem":2171,"children":2172,"page":108},"/docs/5.x/guide/recipes","docs/5.x/3.guide/5.recipes",[2173,2176,2179,2182],{"title":364,"path":2174,"stem":2175,"titleTemplate":6},"/docs/5.x/guide/recipes/custom-routing","docs/5.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":2177,"stem":2178,"titleTemplate":6},"/docs/5.x/guide/recipes/vite-plugin","docs/5.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":2180,"stem":2181,"titleTemplate":6},"/docs/5.x/guide/recipes/custom-usefetch","docs/5.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":2183,"stem":2184,"titleTemplate":6},"/docs/5.x/guide/recipes/sessions-and-authentication","docs/5.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":2186,"stem":2187,"children":2188,"page":108},"/docs/5.x/guide/going-further","docs/5.x/3.guide/6.going-further",[2189,2192,2195,2198,2201,2204,2207,2210,2213,2216],{"title":387,"path":2190,"stem":2191,"titleTemplate":6},"/docs/5.x/guide/going-further/events","docs/5.x/3.guide/6.going-further/1.events",{"title":391,"path":2193,"stem":2194,"titleTemplate":6},"/docs/5.x/guide/going-further/experimental-features","docs/5.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":2196,"stem":2197,"titleTemplate":6},"/docs/5.x/guide/going-further/features","docs/5.x/3.guide/6.going-further/1.features",{"title":399,"path":2199,"stem":2200,"titleTemplate":6},"/docs/5.x/guide/going-further/runtime-config","docs/5.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":2202,"stem":2203,"titleTemplate":6},"/docs/5.x/guide/going-further/nightly-release-channel","docs/5.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":2205,"stem":2206,"titleTemplate":6},"/docs/5.x/guide/going-further/hooks","docs/5.x/3.guide/6.going-further/2.hooks",{"title":411,"path":2208,"stem":2209,"titleTemplate":6},"/docs/5.x/guide/going-further/kit","docs/5.x/3.guide/6.going-further/4.kit",{"title":415,"path":2211,"stem":2212,"titleTemplate":6},"/docs/5.x/guide/going-further/nuxt-app","docs/5.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":2214,"stem":2215,"titleTemplate":6},"/docs/5.x/guide/going-further/layers","docs/5.x/3.guide/6.going-further/7.layers",{"title":423,"path":2217,"stem":2218,"titleTemplate":6},"/docs/5.x/guide/going-further/debugging","docs/5.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":2220,"stem":2221,"children":2222,"page":108},"/docs/5.x/api","docs/5.x/4.api",[2223,2275,2369,2460,2512,2570,2580],{"title":434,"titleTemplate":435,"icon":324,"path":2224,"stem":2225,"children":2226,"page":108},"/docs/5.x/api/components","docs/5.x/4.api/1.components",[2227,2230,2233,2236,2239,2242,2245,2248,2251,2254,2257,2260,2263,2266,2269,2272],{"title":440,"path":2228,"stem":2229,"titleTemplate":6},"/docs/5.x/api/components/client-only","docs/5.x/4.api/1.components/1.client-only",{"title":444,"path":2231,"stem":2232,"titleTemplate":6},"/docs/5.x/api/components/dev-only","docs/5.x/4.api/1.components/1.dev-only",{"title":448,"path":2234,"stem":2235,"titleTemplate":6},"/docs/5.x/api/components/nuxt-client-fallback","docs/5.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":2237,"stem":2238,"titleTemplate":6},"/docs/5.x/api/components/nuxt-picture","docs/5.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":2240,"stem":2241,"titleTemplate":6},"/docs/5.x/api/components/teleports","docs/5.x/4.api/1.components/11.teleports",{"title":460,"path":2243,"stem":2244,"titleTemplate":6},"/docs/5.x/api/components/nuxt-route-announcer","docs/5.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":2246,"stem":2247,"titleTemplate":6},"/docs/5.x/api/components/nuxt-time","docs/5.x/4.api/1.components/13.nuxt-time",{"title":1434,"path":2249,"stem":2250,"titleTemplate":6},"/docs/5.x/api/components/nuxt-announcer","docs/5.x/4.api/1.components/14.nuxt-announcer",{"title":468,"path":2252,"stem":2253,"titleTemplate":6},"/docs/5.x/api/components/nuxt-page","docs/5.x/4.api/1.components/2.nuxt-page",{"title":472,"path":2255,"stem":2256,"titleTemplate":6},"/docs/5.x/api/components/nuxt-layout","docs/5.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":2258,"stem":2259,"titleTemplate":6},"/docs/5.x/api/components/nuxt-link","docs/5.x/4.api/1.components/4.nuxt-link",{"title":480,"path":2261,"stem":2262,"titleTemplate":6},"/docs/5.x/api/components/nuxt-loading-indicator","docs/5.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":2264,"stem":2265,"titleTemplate":6},"/docs/5.x/api/components/nuxt-error-boundary","docs/5.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":2267,"stem":2268,"titleTemplate":6},"/docs/5.x/api/components/nuxt-welcome","docs/5.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":2270,"stem":2271,"titleTemplate":6},"/docs/5.x/api/components/nuxt-island","docs/5.x/4.api/1.components/8.nuxt-island",{"title":496,"path":2273,"stem":2274,"titleTemplate":6},"/docs/5.x/api/components/nuxt-img","docs/5.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":2276,"stem":2277,"children":2278,"page":108},"/docs/5.x/api/composables","docs/5.x/4.api/2.composables",[2279,2282,2285,2288,2291,2294,2297,2300,2303,2306,2309,2312,2315,2318,2321,2324,2327,2330,2333,2336,2339,2342,2345,2348,2351,2354,2357,2360,2363,2366],{"title":507,"path":2280,"stem":2281,"titleTemplate":6},"/docs/5.x/api/composables/on-prehydrate","docs/5.x/4.api/2.composables/on-prehydrate",{"title":1469,"path":2283,"stem":2284,"titleTemplate":6},"/docs/5.x/api/composables/use-announcer","docs/5.x/4.api/2.composables/use-announcer",{"title":511,"path":2286,"stem":2287,"titleTemplate":6},"/docs/5.x/api/composables/use-app-config","docs/5.x/4.api/2.composables/use-app-config",{"title":515,"path":2289,"stem":2290,"titleTemplate":6},"/docs/5.x/api/composables/use-async-data","docs/5.x/4.api/2.composables/use-async-data",{"title":519,"path":2292,"stem":2293,"titleTemplate":6},"/docs/5.x/api/composables/use-cookie","docs/5.x/4.api/2.composables/use-cookie",{"title":523,"path":2295,"stem":2296,"titleTemplate":6},"/docs/5.x/api/composables/use-error","docs/5.x/4.api/2.composables/use-error",{"title":527,"path":2298,"stem":2299,"titleTemplate":6},"/docs/5.x/api/composables/use-fetch","docs/5.x/4.api/2.composables/use-fetch",{"title":531,"path":2301,"stem":2302,"titleTemplate":6},"/docs/5.x/api/composables/use-head","docs/5.x/4.api/2.composables/use-head",{"title":535,"path":2304,"stem":2305,"titleTemplate":6},"/docs/5.x/api/composables/use-head-safe","docs/5.x/4.api/2.composables/use-head-safe",{"title":539,"path":2307,"stem":2308,"titleTemplate":6},"/docs/5.x/api/composables/use-hydration","docs/5.x/4.api/2.composables/use-hydration",{"title":543,"path":2310,"stem":2311,"titleTemplate":6},"/docs/5.x/api/composables/use-lazy-async-data","docs/5.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":2313,"stem":2314,"titleTemplate":6},"/docs/5.x/api/composables/use-lazy-fetch","docs/5.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":2316,"stem":2317,"titleTemplate":6},"/docs/5.x/api/composables/use-loading-indicator","docs/5.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":2319,"stem":2320,"titleTemplate":6},"/docs/5.x/api/composables/use-nuxt-app","docs/5.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":2322,"stem":2323,"titleTemplate":6},"/docs/5.x/api/composables/use-nuxt-data","docs/5.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":2325,"stem":2326,"titleTemplate":6},"/docs/5.x/api/composables/use-preview-mode","docs/5.x/4.api/2.composables/use-preview-mode",{"title":567,"path":2328,"stem":2329,"titleTemplate":6},"/docs/5.x/api/composables/use-request-event","docs/5.x/4.api/2.composables/use-request-event",{"title":571,"path":2331,"stem":2332,"titleTemplate":6},"/docs/5.x/api/composables/use-request-fetch","docs/5.x/4.api/2.composables/use-request-fetch",{"title":575,"path":2334,"stem":2335,"titleTemplate":6},"/docs/5.x/api/composables/use-request-header","docs/5.x/4.api/2.composables/use-request-header",{"title":579,"path":2337,"stem":2338,"titleTemplate":6},"/docs/5.x/api/composables/use-request-headers","docs/5.x/4.api/2.composables/use-request-headers",{"title":583,"path":2340,"stem":2341,"titleTemplate":6},"/docs/5.x/api/composables/use-request-url","docs/5.x/4.api/2.composables/use-request-url",{"title":587,"path":2343,"stem":2344,"titleTemplate":6},"/docs/5.x/api/composables/use-response-header","docs/5.x/4.api/2.composables/use-response-header",{"title":591,"path":2346,"stem":2347,"titleTemplate":6},"/docs/5.x/api/composables/use-route","docs/5.x/4.api/2.composables/use-route",{"title":595,"path":2349,"stem":2350,"titleTemplate":6},"/docs/5.x/api/composables/use-route-announcer","docs/5.x/4.api/2.composables/use-route-announcer",{"title":599,"path":2352,"stem":2353,"titleTemplate":6},"/docs/5.x/api/composables/use-router","docs/5.x/4.api/2.composables/use-router",{"title":603,"path":2355,"stem":2356,"titleTemplate":6},"/docs/5.x/api/composables/use-runtime-config","docs/5.x/4.api/2.composables/use-runtime-config",{"title":607,"path":2358,"stem":2359,"titleTemplate":6},"/docs/5.x/api/composables/use-runtime-hook","docs/5.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":2361,"stem":2362,"titleTemplate":6},"/docs/5.x/api/composables/use-seo-meta","docs/5.x/4.api/2.composables/use-seo-meta",{"title":615,"path":2364,"stem":2365,"titleTemplate":6},"/docs/5.x/api/composables/use-server-seo-meta","docs/5.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":2367,"stem":2368,"titleTemplate":6},"/docs/5.x/api/composables/use-state","docs/5.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":2370,"stem":2371,"children":2372,"page":108},"/docs/5.x/api/utils","docs/5.x/4.api/3.utils",[2373,2376,2379,2382,2385,2388,2391,2394,2397,2400,2403,2406,2409,2412,2415,2418,2421,2424,2427,2430,2433,2436,2439,2442,2445,2448,2451,2454,2457],{"title":630,"path":2374,"stem":2375,"titleTemplate":6},"/docs/5.x/api/utils/dollarfetch","docs/5.x/4.api/3.utils/$fetch",{"title":634,"path":2377,"stem":2378,"titleTemplate":6},"/docs/5.x/api/utils/abort-navigation","docs/5.x/4.api/3.utils/abort-navigation",{"title":638,"path":2380,"stem":2381,"titleTemplate":6},"/docs/5.x/api/utils/add-route-middleware","docs/5.x/4.api/3.utils/add-route-middleware",{"title":642,"path":2383,"stem":2384,"titleTemplate":6},"/docs/5.x/api/utils/call-once","docs/5.x/4.api/3.utils/call-once",{"title":646,"path":2386,"stem":2387,"titleTemplate":6},"/docs/5.x/api/utils/clear-error","docs/5.x/4.api/3.utils/clear-error",{"title":650,"path":2389,"stem":2390,"titleTemplate":6},"/docs/5.x/api/utils/clear-nuxt-data","docs/5.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":2392,"stem":2393,"titleTemplate":6},"/docs/5.x/api/utils/clear-nuxt-state","docs/5.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":2395,"stem":2396,"titleTemplate":6},"/docs/5.x/api/utils/create-error","docs/5.x/4.api/3.utils/create-error",{"title":662,"path":2398,"stem":2399,"titleTemplate":6},"/docs/5.x/api/utils/define-lazy-hydration-component","docs/5.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":2401,"stem":2402,"titleTemplate":6},"/docs/5.x/api/utils/define-nuxt-component","docs/5.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":2404,"stem":2405,"titleTemplate":6},"/docs/5.x/api/utils/define-nuxt-plugin","docs/5.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":2407,"stem":2408,"titleTemplate":6},"/docs/5.x/api/utils/define-nuxt-route-middleware","docs/5.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":2410,"stem":2411,"titleTemplate":6},"/docs/5.x/api/utils/define-page-meta","docs/5.x/4.api/3.utils/define-page-meta",{"title":682,"path":2413,"stem":2414,"titleTemplate":6},"/docs/5.x/api/utils/define-route-rules","docs/5.x/4.api/3.utils/define-route-rules",{"title":686,"path":2416,"stem":2417,"titleTemplate":6},"/docs/5.x/api/utils/navigate-to","docs/5.x/4.api/3.utils/navigate-to",{"title":690,"path":2419,"stem":2420,"titleTemplate":6},"/docs/5.x/api/utils/on-before-route-leave","docs/5.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":2422,"stem":2423,"titleTemplate":6},"/docs/5.x/api/utils/on-before-route-update","docs/5.x/4.api/3.utils/on-before-route-update",{"title":698,"path":2425,"stem":2426,"titleTemplate":6},"/docs/5.x/api/utils/on-nuxt-ready","docs/5.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":2428,"stem":2429,"titleTemplate":6},"/docs/5.x/api/utils/prefetch-components","docs/5.x/4.api/3.utils/prefetch-components",{"title":706,"path":2431,"stem":2432,"titleTemplate":6},"/docs/5.x/api/utils/preload-components","docs/5.x/4.api/3.utils/preload-components",{"title":710,"path":2434,"stem":2435,"titleTemplate":6},"/docs/5.x/api/utils/preload-route-components","docs/5.x/4.api/3.utils/preload-route-components",{"title":714,"path":2437,"stem":2438,"titleTemplate":6},"/docs/5.x/api/utils/prerender-routes","docs/5.x/4.api/3.utils/prerender-routes",{"title":718,"path":2440,"stem":2441,"titleTemplate":6},"/docs/5.x/api/utils/refresh-cookie","docs/5.x/4.api/3.utils/refresh-cookie",{"title":722,"path":2443,"stem":2444,"titleTemplate":6},"/docs/5.x/api/utils/refresh-nuxt-data","docs/5.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":2446,"stem":2447,"titleTemplate":6},"/docs/5.x/api/utils/reload-nuxt-app","docs/5.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":2449,"stem":2450,"titleTemplate":6},"/docs/5.x/api/utils/set-page-layout","docs/5.x/4.api/3.utils/set-page-layout",{"title":734,"path":2452,"stem":2453,"titleTemplate":6},"/docs/5.x/api/utils/set-response-status","docs/5.x/4.api/3.utils/set-response-status",{"title":738,"path":2455,"stem":2456,"titleTemplate":6},"/docs/5.x/api/utils/show-error","docs/5.x/4.api/3.utils/show-error",{"title":742,"path":2458,"stem":2459,"titleTemplate":6},"/docs/5.x/api/utils/update-app-config","docs/5.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":2461,"stem":2462,"children":2463,"page":108},"/docs/5.x/api/commands","docs/5.x/4.api/4.commands",[2464,2467,2470,2473,2476,2479,2482,2485,2488,2491,2494,2497,2500,2503,2506,2509],{"title":753,"path":2465,"stem":2466,"titleTemplate":6},"/docs/5.x/api/commands/add","docs/5.x/4.api/4.commands/add",{"title":757,"path":2468,"stem":2469,"titleTemplate":6},"/docs/5.x/api/commands/analyze","docs/5.x/4.api/4.commands/analyze",{"title":761,"path":2471,"stem":2472,"titleTemplate":6},"/docs/5.x/api/commands/build","docs/5.x/4.api/4.commands/build",{"title":765,"path":2474,"stem":2475,"titleTemplate":6},"/docs/5.x/api/commands/build-module","docs/5.x/4.api/4.commands/build-module",{"title":769,"path":2477,"stem":2478,"titleTemplate":6},"/docs/5.x/api/commands/cleanup","docs/5.x/4.api/4.commands/cleanup",{"title":773,"path":2480,"stem":2481,"titleTemplate":6},"/docs/5.x/api/commands/dev","docs/5.x/4.api/4.commands/dev",{"title":777,"path":2483,"stem":2484,"titleTemplate":6},"/docs/5.x/api/commands/devtools","docs/5.x/4.api/4.commands/devtools",{"title":781,"path":2486,"stem":2487,"titleTemplate":6},"/docs/5.x/api/commands/generate","docs/5.x/4.api/4.commands/generate",{"title":785,"path":2489,"stem":2490,"titleTemplate":6},"/docs/5.x/api/commands/info","docs/5.x/4.api/4.commands/info",{"title":789,"path":2492,"stem":2493,"titleTemplate":6},"/docs/5.x/api/commands/init","docs/5.x/4.api/4.commands/init",{"title":793,"path":2495,"stem":2496,"titleTemplate":6},"/docs/5.x/api/commands/module","docs/5.x/4.api/4.commands/module",{"title":797,"path":2498,"stem":2499,"titleTemplate":6},"/docs/5.x/api/commands/prepare","docs/5.x/4.api/4.commands/prepare",{"title":801,"path":2501,"stem":2502,"titleTemplate":6},"/docs/5.x/api/commands/preview","docs/5.x/4.api/4.commands/preview",{"title":805,"path":2504,"stem":2505,"titleTemplate":6},"/docs/5.x/api/commands/test","docs/5.x/4.api/4.commands/test",{"title":809,"path":2507,"stem":2508,"titleTemplate":6},"/docs/5.x/api/commands/typecheck","docs/5.x/4.api/4.commands/typecheck",{"title":813,"path":2510,"stem":2511,"titleTemplate":6},"/docs/5.x/api/commands/upgrade","docs/5.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":2513,"stem":2514,"children":2515,"page":108},"/docs/5.x/api/kit","docs/5.x/4.api/5.kit",[2516,2519,2522,2525,2528,2531,2534,2537,2540,2543,2546,2549,2552,2555,2558,2561,2564,2567],{"title":276,"path":2517,"stem":2518,"titleTemplate":6},"/docs/5.x/api/kit/modules","docs/5.x/4.api/5.kit/1.modules",{"title":399,"path":2520,"stem":2521,"titleTemplate":6},"/docs/5.x/api/kit/runtime-config","docs/5.x/4.api/5.kit/10.runtime-config",{"title":829,"path":2523,"stem":2524,"titleTemplate":6},"/docs/5.x/api/kit/templates","docs/5.x/4.api/5.kit/10.templates",{"title":833,"path":2526,"stem":2527,"titleTemplate":6},"/docs/5.x/api/kit/nitro","docs/5.x/4.api/5.kit/11.nitro",{"title":837,"path":2529,"stem":2530,"titleTemplate":6},"/docs/5.x/api/kit/resolving","docs/5.x/4.api/5.kit/12.resolving",{"title":841,"path":2532,"stem":2533,"titleTemplate":6},"/docs/5.x/api/kit/logging","docs/5.x/4.api/5.kit/13.logging",{"title":845,"path":2535,"stem":2536,"titleTemplate":6},"/docs/5.x/api/kit/builder","docs/5.x/4.api/5.kit/14.builder",{"title":849,"path":2538,"stem":2539,"titleTemplate":6},"/docs/5.x/api/kit/examples","docs/5.x/4.api/5.kit/15.examples",{"title":84,"path":2541,"stem":2542,"titleTemplate":6},"/docs/5.x/api/kit/layers","docs/5.x/4.api/5.kit/16.layers",{"title":856,"path":2544,"stem":2545,"titleTemplate":6},"/docs/5.x/api/kit/programmatic","docs/5.x/4.api/5.kit/2.programmatic",{"title":860,"path":2547,"stem":2548,"titleTemplate":6},"/docs/5.x/api/kit/compatibility","docs/5.x/4.api/5.kit/3.compatibility",{"title":268,"path":2550,"stem":2551,"titleTemplate":6},"/docs/5.x/api/kit/autoimports","docs/5.x/4.api/5.kit/4.autoimports",{"title":434,"path":2553,"stem":2554,"titleTemplate":6},"/docs/5.x/api/kit/components","docs/5.x/4.api/5.kit/5.components",{"title":870,"path":2556,"stem":2557,"titleTemplate":6},"/docs/5.x/api/kit/context","docs/5.x/4.api/5.kit/6.context",{"title":874,"path":2559,"stem":2560,"titleTemplate":6},"/docs/5.x/api/kit/pages","docs/5.x/4.api/5.kit/7.pages",{"title":878,"path":2562,"stem":2563,"titleTemplate":6},"/docs/5.x/api/kit/layout","docs/5.x/4.api/5.kit/8.layout",{"title":882,"path":2565,"stem":2566,"titleTemplate":6},"/docs/5.x/api/kit/head","docs/5.x/4.api/5.kit/9.head",{"title":886,"path":2568,"stem":2569,"titleTemplate":6},"/docs/5.x/api/kit/plugins","docs/5.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":2571,"stem":2572,"children":2573,"page":108},"/docs/5.x/api/advanced","docs/5.x/4.api/6.advanced",[2574,2577],{"title":407,"path":2575,"stem":2576,"titleTemplate":6},"/docs/5.x/api/advanced/hooks","docs/5.x/4.api/6.advanced/1.hooks",{"title":899,"path":2578,"stem":2579,"titleTemplate":6},"/docs/5.x/api/advanced/import-meta","docs/5.x/4.api/6.advanced/2.import-meta",{"title":903,"path":2581,"stem":2582,"titleTemplate":906,"icon":32},"/docs/5.x/api/nuxt-config","docs/5.x/4.api/6.nuxt-config",{"title":849,"titleTemplate":908,"icon":909,"path":2584,"stem":2585,"children":2586,"page":108},"/docs/5.x/examples","docs/5.x/4.examples",[2587,2590,2609,2622,2653],{"title":914,"path":2588,"stem":2589,"titleTemplate":6},"/docs/5.x/examples/hello-world","docs/5.x/4.examples/0.hello-world",{"title":395,"path":2591,"stem":2592,"children":2593,"page":108},"/docs/5.x/examples/features","docs/5.x/4.examples/1.features",[2594,2597,2600,2603,2606],{"title":922,"path":2595,"stem":2596,"titleTemplate":6},"/docs/5.x/examples/features/auto-imports","docs/5.x/4.examples/1.features/1.auto-imports",{"title":64,"path":2598,"stem":2599,"titleTemplate":6},"/docs/5.x/examples/features/data-fetching","docs/5.x/4.examples/1.features/2.data-fetching",{"title":69,"path":2601,"stem":2602,"titleTemplate":6},"/docs/5.x/examples/features/state-management","docs/5.x/4.examples/1.features/3.state-management",{"title":932,"path":2604,"stem":2605,"titleTemplate":6},"/docs/5.x/examples/features/meta-tags","docs/5.x/4.examples/1.features/4.meta-tags",{"title":936,"path":2607,"stem":2608,"titleTemplate":6},"/docs/5.x/examples/features/layouts","docs/5.x/4.examples/1.features/5.layouts",{"title":49,"path":2610,"stem":2611,"children":2612,"page":108},"/docs/5.x/examples/routing","docs/5.x/4.examples/2.routing",[2613,2616,2619],{"title":944,"path":2614,"stem":2615,"titleTemplate":6},"/docs/5.x/examples/routing/middleware","docs/5.x/4.examples/2.routing/middleware",{"title":874,"path":2617,"stem":2618,"titleTemplate":6},"/docs/5.x/examples/routing/pages","docs/5.x/4.examples/2.routing/pages",{"title":951,"path":2620,"stem":2621,"titleTemplate":6},"/docs/5.x/examples/routing/universal-router","docs/5.x/4.examples/2.routing/universal-router",{"title":890,"path":2623,"stem":2624,"children":2625,"page":108},"/docs/5.x/examples/advanced","docs/5.x/4.examples/4.advanced",[2626,2629,2632,2635,2638,2641,2644,2647,2650],{"title":84,"path":2627,"stem":2628,"titleTemplate":6},"/docs/5.x/examples/advanced/config-extends","docs/5.x/4.examples/4.advanced/config-extends",{"title":74,"path":2630,"stem":2631,"titleTemplate":6},"/docs/5.x/examples/advanced/error-handling","docs/5.x/4.examples/4.advanced/error-handling",{"title":965,"path":2633,"stem":2634,"titleTemplate":6},"/docs/5.x/examples/advanced/jsx","docs/5.x/4.examples/4.advanced/jsx",{"title":969,"path":2636,"stem":2637,"titleTemplate":6},"/docs/5.x/examples/advanced/locale","docs/5.x/4.examples/4.advanced/locale",{"title":973,"path":2639,"stem":2640,"titleTemplate":6},"/docs/5.x/examples/advanced/module-extend-pages","docs/5.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":2642,"stem":2643,"titleTemplate":6},"/docs/5.x/examples/advanced/teleport","docs/5.x/4.examples/4.advanced/teleport",{"title":99,"path":2645,"stem":2646,"titleTemplate":6},"/docs/5.x/examples/advanced/testing","docs/5.x/4.examples/4.advanced/testing",{"title":519,"path":2648,"stem":2649,"titleTemplate":6},"/docs/5.x/examples/advanced/use-cookie","docs/5.x/4.examples/4.advanced/use-cookie",{"title":987,"path":2651,"stem":2652,"titleTemplate":6},"/docs/5.x/examples/advanced/use-custom-fetch-composable","docs/5.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":2654,"stem":2655,"children":2656,"page":108},"/docs/5.x/examples/experimental","docs/5.x/4.examples/7.experimental",[2657],{"title":996,"path":2658,"stem":2659,"titleTemplate":6},"/docs/5.x/examples/experimental/wasm","docs/5.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":2661,"stem":2662,"children":2663,"page":108},"/docs/5.x/community","docs/5.x/5.community",[2664,2667,2670,2673,2676,2679],{"title":1007,"path":2665,"stem":2666,"titleTemplate":6,"icon":1010},"/docs/5.x/community/getting-help","docs/5.x/5.community/2.getting-help",{"title":1012,"path":2668,"stem":2669,"titleTemplate":6,"icon":1015},"/docs/5.x/community/reporting-bugs","docs/5.x/5.community/3.reporting-bugs",{"title":1017,"path":2671,"stem":2672,"titleTemplate":6,"icon":1020},"/docs/5.x/community/contribution","docs/5.x/5.community/4.contribution",{"title":1022,"path":2674,"stem":2675,"titleTemplate":6,"icon":1025},"/docs/5.x/community/framework-contribution","docs/5.x/5.community/5.framework-contribution",{"title":1027,"path":2677,"stem":2678,"titleTemplate":6,"icon":1030},"/docs/5.x/community/roadmap","docs/5.x/5.community/6.roadmap",{"title":1032,"path":2680,"stem":2681,"titleTemplate":6,"icon":1035},"/docs/5.x/community/changelog","docs/5.x/5.community/7.changelog",{"title":1037,"titleTemplate":1038,"icon":1039,"path":2683,"stem":2684,"children":2685,"page":108},"/docs/5.x/bridge","docs/5.x/6.bridge",[2686,2689,2692,2695,2698,2701,2704,2707,2710,2713],{"title":1044,"path":2687,"stem":2688,"titleTemplate":6},"/docs/5.x/bridge/overview","docs/5.x/6.bridge/1.overview",{"title":29,"path":2690,"stem":2691,"titleTemplate":6},"/docs/5.x/bridge/configuration","docs/5.x/6.bridge/10.configuration",{"title":280,"path":2693,"stem":2694,"titleTemplate":6},"/docs/5.x/bridge/typescript","docs/5.x/6.bridge/2.typescript",{"title":1054,"path":2696,"stem":2697,"titleTemplate":6},"/docs/5.x/bridge/bridge-composition-api","docs/5.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":2699,"stem":2700,"titleTemplate":6},"/docs/5.x/bridge/plugins-and-middleware","docs/5.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":2702,"stem":2703,"titleTemplate":6},"/docs/5.x/bridge/nuxt3-compatible-api","docs/5.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":2705,"stem":2706,"titleTemplate":6},"/docs/5.x/bridge/meta","docs/5.x/6.bridge/6.meta",{"title":399,"path":2708,"stem":2709,"titleTemplate":6},"/docs/5.x/bridge/runtime-config","docs/5.x/6.bridge/7.runtime-config",{"title":833,"path":2711,"stem":2712,"titleTemplate":6},"/docs/5.x/bridge/nitro","docs/5.x/6.bridge/8.nitro",{"title":1075,"path":2714,"stem":2715,"titleTemplate":6},"/docs/5.x/bridge/vite","docs/5.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":2717,"stem":2718,"children":2719,"page":108},"/docs/5.x/migration","docs/5.x/7.migration",[2720,2723,2726,2729,2732,2735,2738,2741,2744,2747,2750],{"title":1044,"path":2721,"stem":2722,"titleTemplate":6},"/docs/5.x/migration/overview","docs/5.x/7.migration/1.overview",{"title":1088,"path":2724,"stem":2725,"titleTemplate":6},"/docs/5.x/migration/bundling","docs/5.x/7.migration/10.bundling",{"title":79,"path":2727,"stem":2728,"titleTemplate":6},"/docs/5.x/migration/server","docs/5.x/7.migration/11.server",{"title":29,"path":2730,"stem":2731,"titleTemplate":6},"/docs/5.x/migration/configuration","docs/5.x/7.migration/2.configuration",{"title":276,"path":2733,"stem":2734,"titleTemplate":6},"/docs/5.x/migration/module-authors","docs/5.x/7.migration/20.module-authors",{"title":922,"path":2736,"stem":2737,"titleTemplate":6},"/docs/5.x/migration/auto-imports","docs/5.x/7.migration/3.auto-imports",{"title":932,"path":2739,"stem":2740,"titleTemplate":6},"/docs/5.x/migration/meta","docs/5.x/7.migration/4.meta",{"title":1058,"path":2742,"stem":2743,"titleTemplate":6},"/docs/5.x/migration/plugins-and-middleware","docs/5.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":2745,"stem":2746,"titleTemplate":6},"/docs/5.x/migration/pages-and-layouts","docs/5.x/7.migration/6.pages-and-layouts",{"title":1114,"path":2748,"stem":2749,"titleTemplate":6},"/docs/5.x/migration/component-options","docs/5.x/7.migration/7.component-options",{"title":399,"path":2751,"stem":2752,"titleTemplate":6},"/docs/5.x/migration/runtime-config","docs/5.x/7.migration/8.runtime-config",{"title":2754,"path":2755,"stem":2756,"children":2757,"page":108},"Blog","/blog","blog",[2758,2762,2766,2770,2774,2778,2782,2786,2790,2794,2798,2802,2806,2810,2814,2818,2822,2826,2830,2834,2838],{"title":2759,"path":2760,"stem":2761},"Announcing 3.0","/blog/v3","blog/1.v3",{"title":2763,"path":2764,"stem":2765},"Nuxt 3.3","/blog/v3-3","blog/10.v3-3",{"title":2767,"path":2768,"stem":2769},"Nuxt 3.4","/blog/v3-4","blog/11.v3-4",{"title":2771,"path":2772,"stem":2773},"Nuxt 3.5","/blog/v3-5","blog/12.v3-5",{"title":2775,"path":2776,"stem":2777},"Nuxt 3.6","/blog/v3-6","blog/13.v3-6",{"title":2779,"path":2780,"stem":2781},"Nuxt on the Edge","/blog/nuxt-on-the-edge","blog/14.nuxt-on-the-edge",{"title":2783,"path":2784,"stem":2785},"Nuxt DevTools v1.0","/blog/nuxt-devtools-v1-0","blog/18.nuxt-devtools-v1-0",{"title":2787,"path":2788,"stem":2789},"Nuxt: A vision for 2023","/blog/vision-2023","blog/2.vision-2023",{"title":2791,"path":2792,"stem":2793},"The Evolution of Shiki v1.0","/blog/shiki-v1","blog/21.shiki-v1",{"title":2795,"path":2796,"stem":2797},"Refreshed Nuxt ESLint Integrations","/blog/eslint-module","blog/24.eslint-module",{"title":2799,"path":2800,"stem":2801},"Introducing Nuxt Scripts","/blog/nuxt-scripts","blog/26.nuxt-scripts",{"title":2803,"path":2804,"stem":2805},"Introducing Nuxt Icon v1","/blog/nuxt-icon-v1-0","blog/29.nuxt-icon-v1-0",{"title":2807,"path":2808,"stem":2809},"Introducing Nuxt DevTools","/blog/introducing-nuxt-devtools","blog/3.introducing-nuxt-devtools",{"title":2811,"path":2812,"stem":2813},"Announcing Nuxt 3 Release Candidate","/blog/nuxt3-rc","blog/3.nuxt3-rc",{"title":2815,"path":2816,"stem":2817},"Nuxt 2 End-of-Life (EOL)","/blog/nuxt2-eol","blog/4.nuxt2-eol",{"title":2819,"path":2820,"stem":2821},"Introducing Nuxt 3 Beta","/blog/nuxt3-beta","blog/4.nuxt3-beta",{"title":2823,"path":2824,"stem":2825},"Going Full Static","/blog/going-full-static","blog/5.going-full-static",{"title":2827,"path":2828,"stem":2829},"Introducing Smart Prefetching","/blog/introducing-smart-prefetching","blog/6.introducing-smart-prefetching",{"title":2831,"path":2832,"stem":2833},"Understanding how fetch works in Nuxt 2.12","/blog/understanding-how-fetch-works-in-nuxt-2-12","blog/7.understanding-how-fetch-works-in-nuxt-2-12",{"title":2835,"path":2836,"stem":2837},"Nuxt 2 Static Improvements","/blog/nuxt-static-improvements","blog/8.nuxt-static-improvements",{"title":2839,"path":2840,"stem":2841},"Nuxt 2: From Terminal to Browser","/blog/nuxtjs-from-terminal-to-browser","blog/9.nuxtjs-from-terminal-to-browser",{"v5":2843,"v4":2844,"v3":2845,"v2":2846},"5 (nightly)","4.3.1","3.21.1","2.18.1",{"id":2848,"title":132,"body":2849,"description":6363,"extension":6364,"links":6,"meta":6365,"navigation":6368,"path":133,"seo":6369,"stem":134,"titleTemplate":6,"__hash__":6370},"docsv3/docs/3.x/2.directory-structure/1.components.md",{"type":2850,"value":2851,"toc":6342},"minimark",[2852,2856,2903,2983,2988,2991,3033,3036,3050,3064,3075,3177,3191,3195,3240,3243,3394,3403,3408,3411,3451,3462,3471,3475,3482,3488,3676,3680,3683,3686,3689,3694,3697,3706,3718,3724,3727,3776,3786,3801,3806,3809,3812,3860,3871,3876,3879,3936,3950,3961,3966,3969,4026,4037,4042,4045,4102,4107,4110,4257,4261,4264,4312,4316,4323,4459,4463,4466,4530,4534,4540,4766,4770,4776,4954,4959,4963,4977,5166,5170,5184,5266,5270,5277,5298,5350,5358,5376,5384,5388,5391,5398,5402,5411,5415,5418,5421,5424,5472,5479,5501,5579,5595,5600,5605,5610,5615,5619,5628,5635,5726,5739,5743,5753,5756,5781,5786,5793,5805,5809,5818,5848,5898,5902,5910,5912,5916,5919,5932,5935,6019,6029,6191,6198,6241,6250,6329,6335,6338],[2853,2854,2855],"p",{},"Nuxt automatically imports any components in this directory (along with components that are registered by any modules you may be using).",[2857,2858,2863],"pre",{"className":2859,"code":2860,"filename":110,"language":2861,"meta":2862,"style":2862},"language-bash shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","-| components/\n---| AppHeader.vue\n---| AppFooter.vue\n","bash","",[2864,2865,2866,2882,2893],"code",{"__ignoreMap":2862},[2867,2868,2871,2875,2879],"span",{"class":2869,"line":2870},"line",1,[2867,2872,2874],{"class":2873},"s52Pk","-",[2867,2876,2878],{"class":2877},"sDfIl","|",[2867,2880,2881],{"class":2873}," components/\n",[2867,2883,2885,2888,2890],{"class":2869,"line":2884},2,[2867,2886,2887],{"class":2873},"---",[2867,2889,2878],{"class":2877},[2867,2891,2892],{"class":2873}," AppHeader.vue\n",[2867,2894,2896,2898,2900],{"class":2869,"line":2895},3,[2867,2897,2887],{"class":2873},[2867,2899,2878],{"class":2877},[2867,2901,2902],{"class":2873}," AppFooter.vue\n",[2857,2904,2908],{"className":2905,"code":2906,"filename":219,"language":2907,"meta":2862,"style":2862},"language-html shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","\u003Ctemplate>\n  \u003Cdiv>\n    \u003CAppHeader />\n    \u003CNuxtPage />\n    \u003CAppFooter />\n  \u003C/div>\n\u003C/template>\n","html",[2864,2909,2910,2922,2932,2943,2953,2963,2973],{"__ignoreMap":2862},[2867,2911,2912,2915,2919],{"class":2869,"line":2870},[2867,2913,2914],{"class":2877},"\u003C",[2867,2916,2918],{"class":2917},"sRlkE","template",[2867,2920,2921],{"class":2877},">\n",[2867,2923,2924,2927,2930],{"class":2869,"line":2884},[2867,2925,2926],{"class":2877},"  \u003C",[2867,2928,2929],{"class":2917},"div",[2867,2931,2921],{"class":2877},[2867,2933,2934,2937,2940],{"class":2869,"line":2895},[2867,2935,2936],{"class":2877},"    \u003C",[2867,2938,2939],{"class":2917},"AppHeader",[2867,2941,2942],{"class":2877}," />\n",[2867,2944,2946,2948,2951],{"class":2869,"line":2945},4,[2867,2947,2936],{"class":2877},[2867,2949,2950],{"class":2917},"NuxtPage",[2867,2952,2942],{"class":2877},[2867,2954,2956,2958,2961],{"class":2869,"line":2955},5,[2867,2957,2936],{"class":2877},[2867,2959,2960],{"class":2917},"AppFooter",[2867,2962,2942],{"class":2877},[2867,2964,2966,2969,2971],{"class":2869,"line":2965},6,[2867,2967,2968],{"class":2877},"  \u003C/",[2867,2970,2929],{"class":2917},[2867,2972,2921],{"class":2877},[2867,2974,2976,2979,2981],{"class":2869,"line":2975},7,[2867,2977,2978],{"class":2877},"\u003C/",[2867,2980,2918],{"class":2917},[2867,2982,2921],{"class":2877},[2984,2985,2987],"h2",{"id":2986},"component-names","Component Names",[2853,2989,2990],{},"If you have a component in nested directories such as:",[2857,2992,2994],{"className":2859,"code":2993,"filename":110,"language":2861,"meta":2862,"style":2862},"-| components/\n---| base/\n-----| foo/\n-------| Button.vue\n",[2864,2995,2996,3004,3013,3023],{"__ignoreMap":2862},[2867,2997,2998,3000,3002],{"class":2869,"line":2870},[2867,2999,2874],{"class":2873},[2867,3001,2878],{"class":2877},[2867,3003,2881],{"class":2873},[2867,3005,3006,3008,3010],{"class":2869,"line":2884},[2867,3007,2887],{"class":2873},[2867,3009,2878],{"class":2877},[2867,3011,3012],{"class":2873}," base/\n",[2867,3014,3015,3018,3020],{"class":2869,"line":2895},[2867,3016,3017],{"class":2873},"-----",[2867,3019,2878],{"class":2877},[2867,3021,3022],{"class":2873}," foo/\n",[2867,3024,3025,3028,3030],{"class":2869,"line":2945},[2867,3026,3027],{"class":2873},"-------",[2867,3029,2878],{"class":2877},[2867,3031,3032],{"class":2873}," Button.vue\n",[2853,3034,3035],{},"... then the component's name will be based on its own path directory and filename, with duplicate segments being removed. Therefore, the component's name will be:",[2857,3037,3039],{"className":2905,"code":3038,"language":2907,"meta":2862,"style":2862},"\u003CBaseFooButton />\n",[2864,3040,3041],{"__ignoreMap":2862},[2867,3042,3043,3045,3048],{"class":2869,"line":2870},[2867,3044,2914],{"class":2877},[2867,3046,3047],{"class":2917},"BaseFooButton",[2867,3049,2942],{"class":2877},[3051,3052,3053],"note",{},[2853,3054,3055,3056,3059,3060,3063],{},"For clarity, we recommend that the component's filename matches its name. So, in the example above, you could rename ",[2864,3057,3058],{},"Button.vue"," to be ",[2864,3061,3062],{},"BaseFooButton.vue",".",[2853,3065,3066,3067,3070,3071,3074],{},"If you want to auto-import components based only on its name, not path, then you need to set ",[2864,3068,3069],{},"pathPrefix"," option to ",[2864,3072,3073],{},"false"," using extended form of the configuration object:",[2857,3076,3081],{"className":3077,"code":3078,"filename":233,"language":3079,"meta":3080,"style":2862},"language-ts shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight has-diff","export default defineNuxtConfig({\n  components: [\n    {\n      path: '~/components',\n      pathPrefix: false, // [!code ++]\n    },\n  ],\n})\n","ts","twoslash",[2864,3082,3083,3103,3114,3119,3139,3156,3161,3168],{"__ignoreMap":2862},[2867,3084,3085,3089,3092,3096,3100],{"class":2869,"line":2870},[2867,3086,3088],{"class":3087},"s8R28","export",[2867,3090,3091],{"class":3087}," default",[2867,3093,3095],{"class":3094},"s3cPz"," defineNuxtConfig",[2867,3097,3099],{"class":3098},"sZSNi","(",[2867,3101,3102],{"class":2877},"{\n",[2867,3104,3105,3108,3111],{"class":2869,"line":2884},[2867,3106,3107],{"class":2917},"  components",[2867,3109,3110],{"class":2877},":",[2867,3112,3113],{"class":3098}," [\n",[2867,3115,3116],{"class":2869,"line":2895},[2867,3117,3118],{"class":2877},"    {\n",[2867,3120,3121,3124,3126,3129,3133,3136],{"class":2869,"line":2945},[2867,3122,3123],{"class":2917},"      path",[2867,3125,3110],{"class":2877},[2867,3127,3128],{"class":2877}," '",[2867,3130,3132],{"class":3131},"sGFVr","~/components",[2867,3134,3135],{"class":2877},"'",[2867,3137,3138],{"class":2877},",\n",[2867,3140,3144,3147,3149,3153],{"class":3141,"line":2955},[2869,3142,3143],"diff","add",[2867,3145,3146],{"class":2917},"      pathPrefix",[2867,3148,3110],{"class":2877},[2867,3150,3152],{"class":3151},"sbKd-"," false",[2867,3154,3155],{"class":2877},",",[2867,3157,3158],{"class":2869,"line":2965},[2867,3159,3160],{"class":2877},"    },\n",[2867,3162,3163,3166],{"class":2869,"line":2975},[2867,3164,3165],{"class":3098},"  ]",[2867,3167,3138],{"class":2877},[2867,3169,3171,3174],{"class":2869,"line":3170},8,[2867,3172,3173],{"class":2877},"}",[2867,3175,3176],{"class":3098},")\n",[2853,3178,3179,3180,3183,3184,3187,3188,3063],{},"This registers the components using the same strategy as used in Nuxt 2. For example, ",[2864,3181,3182],{},"~/components/Some/MyComponent.vue"," will be usable as ",[2864,3185,3186],{},"\u003CMyComponent>"," and not ",[2864,3189,3190],{},"\u003CSomeMyComponent>",[2984,3192,3194],{"id":3193},"dynamic-components","Dynamic Components",[2853,3196,3197,3198,3228,3229,3232,3233,3236,3237,3239],{},"If you want to use the Vue ",[2864,3199,3202,3204,3207,3210,3214,3217,3220,3223,3225],{"className":3200,"language":3201,"style":2862},"language-vue shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","vue",[2867,3203,2914],{"class":2877},[2867,3205,3206],{"class":2917},"component",[2867,3208,3209],{"class":2877}," :",[2867,3211,3213],{"class":3212},"smZ93","is",[2867,3215,3216],{"class":2877},"=",[2867,3218,3219],{"class":2877},"\"",[2867,3221,3222],{"class":3098},"someComputedComponent",[2867,3224,3219],{"class":2877},[2867,3226,3227],{"class":2877},">"," syntax, you need to use the ",[2864,3230,3231],{},"resolveComponent"," helper provided by Vue or import the component directly from ",[2864,3234,3235],{},"#components"," and pass it into ",[2864,3238,3213],{}," prop.",[2853,3241,3242],{},"For example:",[2857,3244,3247],{"className":3200,"code":3245,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Cscript setup lang=\"ts\">\nimport { SomeComponent } from '#components'\n\nconst MyButton = resolveComponent('MyButton')\n\u003C/script>\n\n\u003Ctemplate>\n  \u003Ccomponent :is=\"clickable ? MyButton : 'div'\" />\n  \u003Ccomponent :is=\"SomeComponent\" />\n\u003C/template>\n","pages/index.vue",[2864,3248,3249,3272,3296,3301,3325,3333,3337,3345,3365,3385],{"__ignoreMap":2862},[2867,3250,3251,3253,3256,3259,3262,3264,3266,3268,3270],{"class":2869,"line":2870},[2867,3252,2914],{"class":2877},[2867,3254,3255],{"class":2917},"script",[2867,3257,3258],{"class":3212}," setup",[2867,3260,3261],{"class":3212}," lang",[2867,3263,3216],{"class":2877},[2867,3265,3219],{"class":2877},[2867,3267,3079],{"class":3131},[2867,3269,3219],{"class":2877},[2867,3271,2921],{"class":2877},[2867,3273,3274,3277,3280,3283,3286,3289,3291,3293],{"class":2869,"line":2884},[2867,3275,3276],{"class":3087},"import",[2867,3278,3279],{"class":2877}," {",[2867,3281,3282],{"class":3098}," SomeComponent",[2867,3284,3285],{"class":2877}," }",[2867,3287,3288],{"class":3087}," from",[2867,3290,3128],{"class":2877},[2867,3292,3235],{"class":3131},[2867,3294,3295],{"class":2877},"'\n",[2867,3297,3298],{"class":2869,"line":2895},[2867,3299,3300],{"emptyLinePlaceholder":1196},"\n",[2867,3302,3303,3306,3309,3311,3314,3316,3318,3321,3323],{"class":2869,"line":2945},[2867,3304,3305],{"class":3212},"const",[2867,3307,3308],{"class":3098}," MyButton ",[2867,3310,3216],{"class":2877},[2867,3312,3313],{"class":3094}," resolveComponent",[2867,3315,3099],{"class":3098},[2867,3317,3135],{"class":2877},[2867,3319,3320],{"class":3131},"MyButton",[2867,3322,3135],{"class":2877},[2867,3324,3176],{"class":3098},[2867,3326,3327,3329,3331],{"class":2869,"line":2955},[2867,3328,2978],{"class":2877},[2867,3330,3255],{"class":2917},[2867,3332,2921],{"class":2877},[2867,3334,3335],{"class":2869,"line":2965},[2867,3336,3300],{"emptyLinePlaceholder":1196},[2867,3338,3339,3341,3343],{"class":2869,"line":2975},[2867,3340,2914],{"class":2877},[2867,3342,2918],{"class":2917},[2867,3344,2921],{"class":2877},[2867,3346,3347,3349,3351,3354,3356,3358,3361,3363],{"class":2869,"line":3170},[2867,3348,2926],{"class":2877},[2867,3350,3206],{"class":2917},[2867,3352,3353],{"class":3212}," :is",[2867,3355,3216],{"class":2877},[2867,3357,3219],{"class":2877},[2867,3359,3360],{"class":3131},"clickable ? MyButton : 'div'",[2867,3362,3219],{"class":2877},[2867,3364,2942],{"class":2877},[2867,3366,3368,3370,3372,3374,3376,3378,3381,3383],{"class":2869,"line":3367},9,[2867,3369,2926],{"class":2877},[2867,3371,3206],{"class":2917},[2867,3373,3353],{"class":3212},[2867,3375,3216],{"class":2877},[2867,3377,3219],{"class":2877},[2867,3379,3380],{"class":3131},"SomeComponent",[2867,3382,3219],{"class":2877},[2867,3384,2942],{"class":2877},[2867,3386,3388,3390,3392],{"class":2869,"line":3387},10,[2867,3389,2978],{"class":2877},[2867,3391,2918],{"class":2917},[2867,3393,2921],{"class":2877},[3395,3396,3397],"important",{},[2853,3398,3399,3400,3402],{},"If you are using ",[2864,3401,3231],{}," to handle dynamic components, make sure not to insert anything but the name of the component, which must be a literal string and not be or contain a variable. The string is statically analyzed at the compilation step.",[3404,3405],"video-accordion",{"title":3406,"video-id":3407},"Watch Daniel Roe's short video about resolveComponent()","4kq8E5IUM2U",[2853,3409,3410],{},"Alternatively, though not recommended, you can register all your components globally, which will create async chunks for all your components and make them available throughout your application.",[2857,3412,3415],{"className":3413,"code":3414,"language":3142,"meta":2862,"style":2862},"language-diff shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","  export default defineNuxtConfig({\n    components: {\n+     global: true,\n+     dirs: ['~/components']\n    },\n  })\n",[2864,3416,3417,3422,3427,3435,3442,3446],{"__ignoreMap":2862},[2867,3418,3419],{"class":2869,"line":2870},[2867,3420,3421],{"class":3098},"  export default defineNuxtConfig({\n",[2867,3423,3424],{"class":2869,"line":2884},[2867,3425,3426],{"class":3098},"    components: {\n",[2867,3428,3429,3432],{"class":2869,"line":2895},[2867,3430,3431],{"class":2877},"+",[2867,3433,3434],{"class":3131},"     global: true,\n",[2867,3436,3437,3439],{"class":2869,"line":2945},[2867,3438,3431],{"class":2877},[2867,3440,3441],{"class":3131},"     dirs: ['~/components']\n",[2867,3443,3444],{"class":2869,"line":2955},[2867,3445,3160],{"class":3098},[2867,3447,3448],{"class":2869,"line":2965},[2867,3449,3450],{"class":3098},"  })\n",[2853,3452,3453,3454,3457,3458,3461],{},"You can also selectively register some components globally by placing them in a ",[2864,3455,3456],{},"~/components/global"," directory, or by using a ",[2864,3459,3460],{},".global.vue"," suffix in the filename. As noted above, each global component is rendered in a separate chunk, so be careful not to overuse this feature.",[3051,3463,3464],{},[2853,3465,3466,3467,3470],{},"The ",[2864,3468,3469],{},"global"," option can also be set per component directory.",[2984,3472,3474],{"id":3473},"dynamic-imports","Dynamic Imports",[2853,3476,3477,3478,3481],{},"To dynamically import a component (also known as lazy-loading a component) all you need to do is add the ",[2864,3479,3480],{},"Lazy"," prefix to the component's name. This is particularly useful if the component is not always needed.",[2853,3483,3484,3485,3487],{},"By using the ",[2864,3486,3480],{}," prefix you can delay loading the component code until the right moment, which can be helpful for optimizing your JavaScript bundle size.",[2857,3489,3491],{"className":3200,"code":3490,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Cscript setup lang=\"ts\">\nconst show = ref(false)\n\u003C/script>\n\n\u003Ctemplate>\n  \u003Cdiv>\n    \u003Ch1>Mountains\u003C/h1>\n    \u003CLazyMountainsList v-if=\"show\" />\n    \u003Cbutton\n      v-if=\"!show\"\n      @click=\"show = true\"\n    >\n      Show List\n    \u003C/button>\n  \u003C/div>\n\u003C/template>\n",[2864,3492,3493,3513,3531,3539,3543,3551,3559,3577,3598,3605,3620,3635,3641,3647,3658,3667],{"__ignoreMap":2862},[2867,3494,3495,3497,3499,3501,3503,3505,3507,3509,3511],{"class":2869,"line":2870},[2867,3496,2914],{"class":2877},[2867,3498,3255],{"class":2917},[2867,3500,3258],{"class":3212},[2867,3502,3261],{"class":3212},[2867,3504,3216],{"class":2877},[2867,3506,3219],{"class":2877},[2867,3508,3079],{"class":3131},[2867,3510,3219],{"class":2877},[2867,3512,2921],{"class":2877},[2867,3514,3515,3517,3520,3522,3525,3527,3529],{"class":2869,"line":2884},[2867,3516,3305],{"class":3212},[2867,3518,3519],{"class":3098}," show ",[2867,3521,3216],{"class":2877},[2867,3523,3524],{"class":3094}," ref",[2867,3526,3099],{"class":3098},[2867,3528,3073],{"class":3151},[2867,3530,3176],{"class":3098},[2867,3532,3533,3535,3537],{"class":2869,"line":2895},[2867,3534,2978],{"class":2877},[2867,3536,3255],{"class":2917},[2867,3538,2921],{"class":2877},[2867,3540,3541],{"class":2869,"line":2945},[2867,3542,3300],{"emptyLinePlaceholder":1196},[2867,3544,3545,3547,3549],{"class":2869,"line":2955},[2867,3546,2914],{"class":2877},[2867,3548,2918],{"class":2917},[2867,3550,2921],{"class":2877},[2867,3552,3553,3555,3557],{"class":2869,"line":2965},[2867,3554,2926],{"class":2877},[2867,3556,2929],{"class":2917},[2867,3558,2921],{"class":2877},[2867,3560,3561,3563,3566,3568,3571,3573,3575],{"class":2869,"line":2975},[2867,3562,2936],{"class":2877},[2867,3564,3565],{"class":2917},"h1",[2867,3567,3227],{"class":2877},[2867,3569,3570],{"class":3098},"Mountains",[2867,3572,2978],{"class":2877},[2867,3574,3565],{"class":2917},[2867,3576,2921],{"class":2877},[2867,3578,3579,3581,3584,3587,3589,3591,3594,3596],{"class":2869,"line":3170},[2867,3580,2936],{"class":2877},[2867,3582,3583],{"class":2917},"LazyMountainsList",[2867,3585,3586],{"class":3212}," v-if",[2867,3588,3216],{"class":2877},[2867,3590,3219],{"class":2877},[2867,3592,3593],{"class":3131},"show",[2867,3595,3219],{"class":2877},[2867,3597,2942],{"class":2877},[2867,3599,3600,3602],{"class":2869,"line":3367},[2867,3601,2936],{"class":2877},[2867,3603,3604],{"class":2917},"button\n",[2867,3606,3607,3610,3612,3614,3617],{"class":2869,"line":3387},[2867,3608,3609],{"class":3212},"      v-if",[2867,3611,3216],{"class":2877},[2867,3613,3219],{"class":2877},[2867,3615,3616],{"class":3131},"!show",[2867,3618,3619],{"class":2877},"\"\n",[2867,3621,3623,3626,3628,3630,3633],{"class":2869,"line":3622},11,[2867,3624,3625],{"class":3212},"      @click",[2867,3627,3216],{"class":2877},[2867,3629,3219],{"class":2877},[2867,3631,3632],{"class":3131},"show = true",[2867,3634,3619],{"class":2877},[2867,3636,3638],{"class":2869,"line":3637},12,[2867,3639,3640],{"class":2877},"    >\n",[2867,3642,3644],{"class":2869,"line":3643},13,[2867,3645,3646],{"class":3098},"      Show List\n",[2867,3648,3650,3653,3656],{"class":2869,"line":3649},14,[2867,3651,3652],{"class":2877},"    \u003C/",[2867,3654,3655],{"class":2917},"button",[2867,3657,2921],{"class":2877},[2867,3659,3661,3663,3665],{"class":2869,"line":3660},15,[2867,3662,2968],{"class":2877},[2867,3664,2929],{"class":2917},[2867,3666,2921],{"class":2877},[2867,3668,3670,3672,3674],{"class":2869,"line":3669},16,[2867,3671,2978],{"class":2877},[2867,3673,2918],{"class":2917},[2867,3675,2921],{"class":2877},[2984,3677,3679],{"id":3678},"delayed-or-lazy-hydration","Delayed (or Lazy) Hydration",[2853,3681,3682],{},"Lazy components are great for controlling the chunk sizes in your app, but they don't always enhance runtime performance, as they still load eagerly unless conditionally rendered. In real-world applications, some pages may include a lot of content and a lot of components, and most of the time not all of them need to be interactive as soon as the page is loaded. Having them all load eagerly can negatively impact performance.",[2853,3684,3685],{},"In order to optimize your app, you may want to delay the hydration of some components until they're visible, or until the browser is done with more important tasks.",[2853,3687,3688],{},"Nuxt supports this using lazy (or delayed) hydration, allowing you to control when components become interactive.",[3690,3691,3693],"h3",{"id":3692},"hydration-strategies","Hydration Strategies",[2853,3695,3696],{},"Nuxt provides a range of built-in hydration strategies. Only one strategy can be used per lazy component.",[3051,3698,3699],{},[2853,3700,3701,3702,3705],{},"Any prop change on a lazily hydrated component will trigger hydration immediately. (e.g., changing a prop on a component with ",[2864,3703,3704],{},"hydrate-never"," will cause it to hydrate)",[3707,3708,3709],"warning",{},[2853,3710,3711,3712,3715,3716,3063],{},"Currently Nuxt's built-in lazy hydration only works in single-file components (SFCs), and requires you to define the prop in the template (rather than spreading an object of props via ",[2864,3713,3714],{},"v-bind","). It also does not work with direct imports from ",[2864,3717,3235],{},[3719,3720,3722],"h4",{"id":3721},"hydrate-on-visible",[2864,3723,3721],{},[2853,3725,3726],{},"Hydrates the component when it becomes visible in the viewport.",[2857,3728,3730],{"className":3200,"code":3729,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-visible />\n  \u003C/div>\n\u003C/template>\n",[2864,3731,3732,3740,3748,3760,3768],{"__ignoreMap":2862},[2867,3733,3734,3736,3738],{"class":2869,"line":2870},[2867,3735,2914],{"class":2877},[2867,3737,2918],{"class":2917},[2867,3739,2921],{"class":2877},[2867,3741,3742,3744,3746],{"class":2869,"line":2884},[2867,3743,2926],{"class":2877},[2867,3745,2929],{"class":2917},[2867,3747,2921],{"class":2877},[2867,3749,3750,3752,3755,3758],{"class":2869,"line":2895},[2867,3751,2936],{"class":2877},[2867,3753,3754],{"class":2917},"LazyMyComponent",[2867,3756,3757],{"class":3212}," hydrate-on-visible",[2867,3759,2942],{"class":2877},[2867,3761,3762,3764,3766],{"class":2869,"line":2945},[2867,3763,2968],{"class":2877},[2867,3765,2929],{"class":2917},[2867,3767,2921],{"class":2877},[2867,3769,3770,3772,3774],{"class":2869,"line":2955},[2867,3771,2978],{"class":2877},[2867,3773,2918],{"class":2917},[2867,3775,2921],{"class":2877},[3777,3778,3781],"read-more",{"to":3779,"title":3780},"https://developer.mozilla.org/en-US/docs/Web/API/IntersectionObserver/IntersectionObserver","IntersectionObserver options",[2853,3782,3783,3784,3063],{},"Read more about the options for ",[2864,3785,3721],{},[3051,3787,3788],{},[2853,3789,3790,3791,3063],{},"Under the hood, this uses Vue's built-in ",[3792,3793,3797,3800],"a",{"href":3794,"rel":3795},"https://vuejs.org/guide/components/async#hydrate-on-visible",[3796],"nofollow",[2864,3798,3799],{},"hydrateOnVisible"," strategy",[3719,3802,3804],{"id":3803},"hydrate-on-idle",[2864,3805,3803],{},[2853,3807,3808],{},"Hydrates the component when the browser is idle. This is suitable if you need the component to load as soon as possible, but not block the critical rendering path.",[2853,3810,3811],{},"You can also pass a number which serves as a max timeout.",[2857,3813,3815],{"className":3200,"code":3814,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-idle />\n  \u003C/div>\n\u003C/template>\n",[2864,3816,3817,3825,3833,3844,3852],{"__ignoreMap":2862},[2867,3818,3819,3821,3823],{"class":2869,"line":2870},[2867,3820,2914],{"class":2877},[2867,3822,2918],{"class":2917},[2867,3824,2921],{"class":2877},[2867,3826,3827,3829,3831],{"class":2869,"line":2884},[2867,3828,2926],{"class":2877},[2867,3830,2929],{"class":2917},[2867,3832,2921],{"class":2877},[2867,3834,3835,3837,3839,3842],{"class":2869,"line":2895},[2867,3836,2936],{"class":2877},[2867,3838,3754],{"class":2917},[2867,3840,3841],{"class":3212}," hydrate-on-idle",[2867,3843,2942],{"class":2877},[2867,3845,3846,3848,3850],{"class":2869,"line":2945},[2867,3847,2968],{"class":2877},[2867,3849,2929],{"class":2917},[2867,3851,2921],{"class":2877},[2867,3853,3854,3856,3858],{"class":2869,"line":2955},[2867,3855,2978],{"class":2877},[2867,3857,2918],{"class":2917},[2867,3859,2921],{"class":2877},[3051,3861,3862],{},[2853,3863,3790,3864,3063],{},[3792,3865,3868,3800],{"href":3866,"rel":3867},"https://vuejs.org/guide/components/async#hydrate-on-idle",[3796],[2864,3869,3870],{},"hydrateOnIdle",[3719,3872,3874],{"id":3873},"hydrate-on-interaction",[2864,3875,3873],{},[2853,3877,3878],{},"Hydrates the component after a specified interaction (e.g., click, mouseover).",[2857,3880,3882],{"className":3200,"code":3881,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-interaction=\"mouseover\" />\n  \u003C/div>\n\u003C/template>\n",[2864,3883,3884,3892,3900,3920,3928],{"__ignoreMap":2862},[2867,3885,3886,3888,3890],{"class":2869,"line":2870},[2867,3887,2914],{"class":2877},[2867,3889,2918],{"class":2917},[2867,3891,2921],{"class":2877},[2867,3893,3894,3896,3898],{"class":2869,"line":2884},[2867,3895,2926],{"class":2877},[2867,3897,2929],{"class":2917},[2867,3899,2921],{"class":2877},[2867,3901,3902,3904,3906,3909,3911,3913,3916,3918],{"class":2869,"line":2895},[2867,3903,2936],{"class":2877},[2867,3905,3754],{"class":2917},[2867,3907,3908],{"class":3212}," hydrate-on-interaction",[2867,3910,3216],{"class":2877},[2867,3912,3219],{"class":2877},[2867,3914,3915],{"class":3131},"mouseover",[2867,3917,3219],{"class":2877},[2867,3919,2942],{"class":2877},[2867,3921,3922,3924,3926],{"class":2869,"line":2945},[2867,3923,2968],{"class":2877},[2867,3925,2929],{"class":2917},[2867,3927,2921],{"class":2877},[2867,3929,3930,3932,3934],{"class":2869,"line":2955},[2867,3931,2978],{"class":2877},[2867,3933,2918],{"class":2917},[2867,3935,2921],{"class":2877},[2853,3937,3938,3939,3942,3943,3946,3947,3063],{},"If you do not pass an event or list of events, it defaults to hydrating on ",[2864,3940,3941],{},"pointerenter",", ",[2864,3944,3945],{},"click"," and ",[2864,3948,3949],{},"focus",[3051,3951,3952],{},[2853,3953,3790,3954,3063],{},[3792,3955,3958,3800],{"href":3956,"rel":3957},"https://vuejs.org/guide/components/async#hydrate-on-interaction",[3796],[2864,3959,3960],{},"hydrateOnInteraction",[3719,3962,3964],{"id":3963},"hydrate-on-media-query",[2864,3965,3963],{},[2853,3967,3968],{},"Hydrates the component when the window matches a media query.",[2857,3970,3972],{"className":3200,"code":3971,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-media-query=\"(max-width: 768px)\" />\n  \u003C/div>\n\u003C/template>\n",[2864,3973,3974,3982,3990,4010,4018],{"__ignoreMap":2862},[2867,3975,3976,3978,3980],{"class":2869,"line":2870},[2867,3977,2914],{"class":2877},[2867,3979,2918],{"class":2917},[2867,3981,2921],{"class":2877},[2867,3983,3984,3986,3988],{"class":2869,"line":2884},[2867,3985,2926],{"class":2877},[2867,3987,2929],{"class":2917},[2867,3989,2921],{"class":2877},[2867,3991,3992,3994,3996,3999,4001,4003,4006,4008],{"class":2869,"line":2895},[2867,3993,2936],{"class":2877},[2867,3995,3754],{"class":2917},[2867,3997,3998],{"class":3212}," hydrate-on-media-query",[2867,4000,3216],{"class":2877},[2867,4002,3219],{"class":2877},[2867,4004,4005],{"class":3131},"(max-width: 768px)",[2867,4007,3219],{"class":2877},[2867,4009,2942],{"class":2877},[2867,4011,4012,4014,4016],{"class":2869,"line":2945},[2867,4013,2968],{"class":2877},[2867,4015,2929],{"class":2917},[2867,4017,2921],{"class":2877},[2867,4019,4020,4022,4024],{"class":2869,"line":2955},[2867,4021,2978],{"class":2877},[2867,4023,2918],{"class":2917},[2867,4025,2921],{"class":2877},[3051,4027,4028],{},[2853,4029,3790,4030,3063],{},[3792,4031,4034,3800],{"href":4032,"rel":4033},"https://vuejs.org/guide/components/async#hydrate-on-media-query",[3796],[2864,4035,4036],{},"hydrateOnMediaQuery",[3719,4038,4040],{"id":4039},"hydrate-after",[2864,4041,4039],{},[2853,4043,4044],{},"Hydrates the component after a specified delay (in milliseconds).",[2857,4046,4048],{"className":3200,"code":4047,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent :hydrate-after=\"2000\" />\n  \u003C/div>\n\u003C/template>\n",[2864,4049,4050,4058,4066,4086,4094],{"__ignoreMap":2862},[2867,4051,4052,4054,4056],{"class":2869,"line":2870},[2867,4053,2914],{"class":2877},[2867,4055,2918],{"class":2917},[2867,4057,2921],{"class":2877},[2867,4059,4060,4062,4064],{"class":2869,"line":2884},[2867,4061,2926],{"class":2877},[2867,4063,2929],{"class":2917},[2867,4065,2921],{"class":2877},[2867,4067,4068,4070,4072,4075,4077,4079,4082,4084],{"class":2869,"line":2895},[2867,4069,2936],{"class":2877},[2867,4071,3754],{"class":2917},[2867,4073,4074],{"class":3212}," :hydrate-after",[2867,4076,3216],{"class":2877},[2867,4078,3219],{"class":2877},[2867,4080,4081],{"class":3131},"2000",[2867,4083,3219],{"class":2877},[2867,4085,2942],{"class":2877},[2867,4087,4088,4090,4092],{"class":2869,"line":2945},[2867,4089,2968],{"class":2877},[2867,4091,2929],{"class":2917},[2867,4093,2921],{"class":2877},[2867,4095,4096,4098,4100],{"class":2869,"line":2955},[2867,4097,2978],{"class":2877},[2867,4099,2918],{"class":2917},[2867,4101,2921],{"class":2877},[3719,4103,4105],{"id":4104},"hydrate-when",[2864,4106,4104],{},[2853,4108,4109],{},"Hydrates the component based on a boolean condition.",[2857,4111,4113],{"className":3200,"code":4112,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent :hydrate-when=\"isReady\" />\n  \u003C/div>\n\u003C/template>\n\n\u003Cscript setup lang=\"ts\">\nconst isReady = ref(false)\nfunction myFunction () {\n  // trigger custom hydration strategy...\n  isReady.value = true\n}\n\u003C/script>\n",[2864,4114,4115,4123,4131,4151,4159,4167,4171,4191,4208,4222,4228,4244,4249],{"__ignoreMap":2862},[2867,4116,4117,4119,4121],{"class":2869,"line":2870},[2867,4118,2914],{"class":2877},[2867,4120,2918],{"class":2917},[2867,4122,2921],{"class":2877},[2867,4124,4125,4127,4129],{"class":2869,"line":2884},[2867,4126,2926],{"class":2877},[2867,4128,2929],{"class":2917},[2867,4130,2921],{"class":2877},[2867,4132,4133,4135,4137,4140,4142,4144,4147,4149],{"class":2869,"line":2895},[2867,4134,2936],{"class":2877},[2867,4136,3754],{"class":2917},[2867,4138,4139],{"class":3212}," :hydrate-when",[2867,4141,3216],{"class":2877},[2867,4143,3219],{"class":2877},[2867,4145,4146],{"class":3131},"isReady",[2867,4148,3219],{"class":2877},[2867,4150,2942],{"class":2877},[2867,4152,4153,4155,4157],{"class":2869,"line":2945},[2867,4154,2968],{"class":2877},[2867,4156,2929],{"class":2917},[2867,4158,2921],{"class":2877},[2867,4160,4161,4163,4165],{"class":2869,"line":2955},[2867,4162,2978],{"class":2877},[2867,4164,2918],{"class":2917},[2867,4166,2921],{"class":2877},[2867,4168,4169],{"class":2869,"line":2965},[2867,4170,3300],{"emptyLinePlaceholder":1196},[2867,4172,4173,4175,4177,4179,4181,4183,4185,4187,4189],{"class":2869,"line":2975},[2867,4174,2914],{"class":2877},[2867,4176,3255],{"class":2917},[2867,4178,3258],{"class":3212},[2867,4180,3261],{"class":3212},[2867,4182,3216],{"class":2877},[2867,4184,3219],{"class":2877},[2867,4186,3079],{"class":3131},[2867,4188,3219],{"class":2877},[2867,4190,2921],{"class":2877},[2867,4192,4193,4195,4198,4200,4202,4204,4206],{"class":2869,"line":3170},[2867,4194,3305],{"class":3212},[2867,4196,4197],{"class":3098}," isReady ",[2867,4199,3216],{"class":2877},[2867,4201,3524],{"class":3094},[2867,4203,3099],{"class":3098},[2867,4205,3073],{"class":3151},[2867,4207,3176],{"class":3098},[2867,4209,4210,4213,4216,4219],{"class":2869,"line":3367},[2867,4211,4212],{"class":3212},"function",[2867,4214,4215],{"class":3094}," myFunction",[2867,4217,4218],{"class":2877}," ()",[2867,4220,4221],{"class":2877}," {\n",[2867,4223,4224],{"class":2869,"line":3387},[2867,4225,4227],{"class":4226},"sWuyu","  // trigger custom hydration strategy...\n",[2867,4229,4230,4233,4235,4238,4241],{"class":2869,"line":3622},[2867,4231,4232],{"class":3098},"  isReady",[2867,4234,3063],{"class":2877},[2867,4236,4237],{"class":3098},"value",[2867,4239,4240],{"class":2877}," =",[2867,4242,4243],{"class":3151}," true\n",[2867,4245,4246],{"class":2869,"line":3637},[2867,4247,4248],{"class":2877},"}\n",[2867,4250,4251,4253,4255],{"class":2869,"line":3643},[2867,4252,2978],{"class":2877},[2867,4254,3255],{"class":2917},[2867,4256,2921],{"class":2877},[3719,4258,4259],{"id":3704},[2864,4260,3704],{},[2853,4262,4263],{},"Never hydrates the component.",[2857,4265,4267],{"className":3200,"code":4266,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-never />\n  \u003C/div>\n\u003C/template>\n",[2864,4268,4269,4277,4285,4296,4304],{"__ignoreMap":2862},[2867,4270,4271,4273,4275],{"class":2869,"line":2870},[2867,4272,2914],{"class":2877},[2867,4274,2918],{"class":2917},[2867,4276,2921],{"class":2877},[2867,4278,4279,4281,4283],{"class":2869,"line":2884},[2867,4280,2926],{"class":2877},[2867,4282,2929],{"class":2917},[2867,4284,2921],{"class":2877},[2867,4286,4287,4289,4291,4294],{"class":2869,"line":2895},[2867,4288,2936],{"class":2877},[2867,4290,3754],{"class":2917},[2867,4292,4293],{"class":3212}," hydrate-never",[2867,4295,2942],{"class":2877},[2867,4297,4298,4300,4302],{"class":2869,"line":2945},[2867,4299,2968],{"class":2877},[2867,4301,2929],{"class":2917},[2867,4303,2921],{"class":2877},[2867,4305,4306,4308,4310],{"class":2869,"line":2955},[2867,4307,2978],{"class":2877},[2867,4309,2918],{"class":2917},[2867,4311,2921],{"class":2877},[3690,4313,4315],{"id":4314},"listening-to-hydration-events","Listening to Hydration Events",[2853,4317,4318,4319,4322],{},"All delayed hydration components emit a ",[2864,4320,4321],{},"@hydrated"," event when they are hydrated.",[2857,4324,4326],{"className":3200,"code":4325,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent\n      hydrate-on-visible\n      @hydrated=\"onHydrate\"\n    />\n  \u003C/div>\n\u003C/template>\n\n\u003Cscript setup lang=\"ts\">\nfunction onHydrate () {\n  console.log('Component has been hydrated!')\n}\n\u003C/script>\n",[2864,4327,4328,4336,4344,4351,4356,4370,4375,4383,4391,4395,4415,4426,4447,4451],{"__ignoreMap":2862},[2867,4329,4330,4332,4334],{"class":2869,"line":2870},[2867,4331,2914],{"class":2877},[2867,4333,2918],{"class":2917},[2867,4335,2921],{"class":2877},[2867,4337,4338,4340,4342],{"class":2869,"line":2884},[2867,4339,2926],{"class":2877},[2867,4341,2929],{"class":2917},[2867,4343,2921],{"class":2877},[2867,4345,4346,4348],{"class":2869,"line":2895},[2867,4347,2936],{"class":2877},[2867,4349,4350],{"class":2917},"LazyMyComponent\n",[2867,4352,4353],{"class":2869,"line":2945},[2867,4354,4355],{"class":3212},"      hydrate-on-visible\n",[2867,4357,4358,4361,4363,4365,4368],{"class":2869,"line":2955},[2867,4359,4360],{"class":3212},"      @hydrated",[2867,4362,3216],{"class":2877},[2867,4364,3219],{"class":2877},[2867,4366,4367],{"class":3131},"onHydrate",[2867,4369,3619],{"class":2877},[2867,4371,4372],{"class":2869,"line":2965},[2867,4373,4374],{"class":2877},"    />\n",[2867,4376,4377,4379,4381],{"class":2869,"line":2975},[2867,4378,2968],{"class":2877},[2867,4380,2929],{"class":2917},[2867,4382,2921],{"class":2877},[2867,4384,4385,4387,4389],{"class":2869,"line":3170},[2867,4386,2978],{"class":2877},[2867,4388,2918],{"class":2917},[2867,4390,2921],{"class":2877},[2867,4392,4393],{"class":2869,"line":3367},[2867,4394,3300],{"emptyLinePlaceholder":1196},[2867,4396,4397,4399,4401,4403,4405,4407,4409,4411,4413],{"class":2869,"line":3387},[2867,4398,2914],{"class":2877},[2867,4400,3255],{"class":2917},[2867,4402,3258],{"class":3212},[2867,4404,3261],{"class":3212},[2867,4406,3216],{"class":2877},[2867,4408,3219],{"class":2877},[2867,4410,3079],{"class":3131},[2867,4412,3219],{"class":2877},[2867,4414,2921],{"class":2877},[2867,4416,4417,4419,4422,4424],{"class":2869,"line":3622},[2867,4418,4212],{"class":3212},[2867,4420,4421],{"class":3094}," onHydrate",[2867,4423,4218],{"class":2877},[2867,4425,4221],{"class":2877},[2867,4427,4428,4431,4433,4436,4438,4440,4443,4445],{"class":2869,"line":3637},[2867,4429,4430],{"class":3098},"  console",[2867,4432,3063],{"class":2877},[2867,4434,4435],{"class":3094},"log",[2867,4437,3099],{"class":2917},[2867,4439,3135],{"class":2877},[2867,4441,4442],{"class":3131},"Component has been hydrated!",[2867,4444,3135],{"class":2877},[2867,4446,3176],{"class":2917},[2867,4448,4449],{"class":2869,"line":3643},[2867,4450,4248],{"class":2877},[2867,4452,4453,4455,4457],{"class":2869,"line":3649},[2867,4454,2978],{"class":2877},[2867,4456,3255],{"class":2917},[2867,4458,2921],{"class":2877},[3690,4460,4462],{"id":4461},"caveats-and-best-practices","Caveats and Best Practices",[2853,4464,4465],{},"Delayed hydration can offer performance benefits, but it's essential to use it correctly:",[4467,4468,4469,4477,4487,4497,4521],"ol",{},[4470,4471,4472,4476],"li",{},[4473,4474,4475],"strong",{},"Prioritize In-Viewport Content:"," Avoid delayed hydration for critical, above-the-fold content. It's best suited for content that isn't immediately needed.",[4470,4478,4479,4482,4483,4486],{},[4473,4480,4481],{},"Conditional Rendering:"," When using ",[2864,4484,4485],{},"v-if=\"false\""," on a lazy component, you might not need delayed hydration. You can just use a normal lazy component.",[4470,4488,4489,4492,4493,4496],{},[4473,4490,4491],{},"Shared State:"," Be mindful of shared state (",[2864,4494,4495],{},"v-model",") across multiple components. Updating the model in one component can trigger hydration in all components bound to that model.",[4470,4498,4499,4502,4503],{},[4473,4500,4501],{},"Use Each Strategy's Intended Use Case:"," Each strategy is optimized for a specific purpose.",[4504,4505,4506,4511,4516],"ul",{},[4470,4507,4508,4510],{},[2864,4509,4104],{}," is best for components that might not always need to be hydrated.",[4470,4512,4513,4515],{},[2864,4514,4039],{}," is for components that can wait a specific amount of time.",[4470,4517,4518,4520],{},[2864,4519,3803],{}," is for components that can be hydrated when the browser is idle.",[4470,4522,4523,4529],{},[4473,4524,4525,4526,4528],{},"Avoid ",[2864,4527,3704],{}," on interactive components:"," If a component requires user interaction, it should not be set to never hydrate.",[2984,4531,4533],{"id":4532},"direct-imports","Direct Imports",[2853,4535,4536,4537,4539],{},"You can also explicitly import components from ",[2864,4538,3235],{}," if you want or need to bypass Nuxt's auto-importing functionality.",[2857,4541,4543],{"className":3200,"code":4542,"filename":3246,"language":3201,"meta":2862,"style":2862},"\u003Cscript setup lang=\"ts\">\nimport { LazyMountainsList, NuxtLink } from '#components'\n\nconst show = ref(false)\n\u003C/script>\n\n\u003Ctemplate>\n  \u003Cdiv>\n    \u003Ch1>Mountains\u003C/h1>\n    \u003CLazyMountainsList v-if=\"show\" />\n    \u003Cbutton\n      v-if=\"!show\"\n      @click=\"show = true\"\n    >\n      Show List\n    \u003C/button>\n    \u003CNuxtLink to=\"/\">Home\u003C/NuxtLink>\n  \u003C/div>\n\u003C/template>\n",[2864,4544,4545,4565,4589,4593,4609,4617,4621,4629,4637,4653,4671,4677,4689,4701,4705,4709,4717,4748,4757],{"__ignoreMap":2862},[2867,4546,4547,4549,4551,4553,4555,4557,4559,4561,4563],{"class":2869,"line":2870},[2867,4548,2914],{"class":2877},[2867,4550,3255],{"class":2917},[2867,4552,3258],{"class":3212},[2867,4554,3261],{"class":3212},[2867,4556,3216],{"class":2877},[2867,4558,3219],{"class":2877},[2867,4560,3079],{"class":3131},[2867,4562,3219],{"class":2877},[2867,4564,2921],{"class":2877},[2867,4566,4567,4569,4571,4574,4576,4579,4581,4583,4585,4587],{"class":2869,"line":2884},[2867,4568,3276],{"class":3087},[2867,4570,3279],{"class":2877},[2867,4572,4573],{"class":3098}," LazyMountainsList",[2867,4575,3155],{"class":2877},[2867,4577,4578],{"class":3098}," NuxtLink",[2867,4580,3285],{"class":2877},[2867,4582,3288],{"class":3087},[2867,4584,3128],{"class":2877},[2867,4586,3235],{"class":3131},[2867,4588,3295],{"class":2877},[2867,4590,4591],{"class":2869,"line":2895},[2867,4592,3300],{"emptyLinePlaceholder":1196},[2867,4594,4595,4597,4599,4601,4603,4605,4607],{"class":2869,"line":2945},[2867,4596,3305],{"class":3212},[2867,4598,3519],{"class":3098},[2867,4600,3216],{"class":2877},[2867,4602,3524],{"class":3094},[2867,4604,3099],{"class":3098},[2867,4606,3073],{"class":3151},[2867,4608,3176],{"class":3098},[2867,4610,4611,4613,4615],{"class":2869,"line":2955},[2867,4612,2978],{"class":2877},[2867,4614,3255],{"class":2917},[2867,4616,2921],{"class":2877},[2867,4618,4619],{"class":2869,"line":2965},[2867,4620,3300],{"emptyLinePlaceholder":1196},[2867,4622,4623,4625,4627],{"class":2869,"line":2975},[2867,4624,2914],{"class":2877},[2867,4626,2918],{"class":2917},[2867,4628,2921],{"class":2877},[2867,4630,4631,4633,4635],{"class":2869,"line":3170},[2867,4632,2926],{"class":2877},[2867,4634,2929],{"class":2917},[2867,4636,2921],{"class":2877},[2867,4638,4639,4641,4643,4645,4647,4649,4651],{"class":2869,"line":3367},[2867,4640,2936],{"class":2877},[2867,4642,3565],{"class":2917},[2867,4644,3227],{"class":2877},[2867,4646,3570],{"class":3098},[2867,4648,2978],{"class":2877},[2867,4650,3565],{"class":2917},[2867,4652,2921],{"class":2877},[2867,4654,4655,4657,4659,4661,4663,4665,4667,4669],{"class":2869,"line":3387},[2867,4656,2936],{"class":2877},[2867,4658,3583],{"class":2917},[2867,4660,3586],{"class":3212},[2867,4662,3216],{"class":2877},[2867,4664,3219],{"class":2877},[2867,4666,3593],{"class":3131},[2867,4668,3219],{"class":2877},[2867,4670,2942],{"class":2877},[2867,4672,4673,4675],{"class":2869,"line":3622},[2867,4674,2936],{"class":2877},[2867,4676,3604],{"class":2917},[2867,4678,4679,4681,4683,4685,4687],{"class":2869,"line":3637},[2867,4680,3609],{"class":3212},[2867,4682,3216],{"class":2877},[2867,4684,3219],{"class":2877},[2867,4686,3616],{"class":3131},[2867,4688,3619],{"class":2877},[2867,4690,4691,4693,4695,4697,4699],{"class":2869,"line":3643},[2867,4692,3625],{"class":3212},[2867,4694,3216],{"class":2877},[2867,4696,3219],{"class":2877},[2867,4698,3632],{"class":3131},[2867,4700,3619],{"class":2877},[2867,4702,4703],{"class":2869,"line":3649},[2867,4704,3640],{"class":2877},[2867,4706,4707],{"class":2869,"line":3660},[2867,4708,3646],{"class":3098},[2867,4710,4711,4713,4715],{"class":2869,"line":3669},[2867,4712,3652],{"class":2877},[2867,4714,3655],{"class":2917},[2867,4716,2921],{"class":2877},[2867,4718,4720,4722,4725,4728,4730,4732,4735,4737,4739,4742,4744,4746],{"class":2869,"line":4719},17,[2867,4721,2936],{"class":2877},[2867,4723,4724],{"class":2917},"NuxtLink",[2867,4726,4727],{"class":3212}," to",[2867,4729,3216],{"class":2877},[2867,4731,3219],{"class":2877},[2867,4733,4734],{"class":3131},"/",[2867,4736,3219],{"class":2877},[2867,4738,3227],{"class":2877},[2867,4740,4741],{"class":3098},"Home",[2867,4743,2978],{"class":2877},[2867,4745,4724],{"class":2917},[2867,4747,2921],{"class":2877},[2867,4749,4751,4753,4755],{"class":2869,"line":4750},18,[2867,4752,2968],{"class":2877},[2867,4754,2929],{"class":2917},[2867,4756,2921],{"class":2877},[2867,4758,4760,4762,4764],{"class":2869,"line":4759},19,[2867,4761,2978],{"class":2877},[2867,4763,2918],{"class":2917},[2867,4765,2921],{"class":2877},[2984,4767,4769],{"id":4768},"custom-directories","Custom Directories",[2853,4771,4772,4773,4775],{},"By default, only the ",[2864,4774,3132],{}," directory is scanned. If you want to add other directories, or change how the components are scanned within a subfolder of this directory, you can add additional directories to the configuration:",[2857,4777,4780],{"className":4778,"code":4779,"filename":233,"language":3079,"meta":3080,"style":2862},"language-ts shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","export default defineNuxtConfig({\n  components: [\n    // ~/calendar-module/components/event/Update.vue => \u003CEventUpdate />\n    { path: '~/calendar-module/components' },\n\n    // ~/user-module/components/account/UserDeleteDialog.vue => \u003CUserDeleteDialog />\n    { path: '~/user-module/components', pathPrefix: false },\n\n    // ~/components/special-components/Btn.vue => \u003CSpecialBtn />\n    { path: '~/components/special-components', prefix: 'Special' },\n\n    // It's important that this comes last if you have overrides you wish to apply\n    // to sub-directories of `~/components`.\n    //\n    // ~/components/Btn.vue => \u003CBtn />\n    // ~/components/base/Btn.vue => \u003CBaseBtn />\n    '~/components',\n  ],\n})\n",[2864,4781,4782,4794,4802,4807,4827,4831,4836,4862,4866,4871,4902,4906,4911,4916,4921,4926,4931,4942,4948],{"__ignoreMap":2862},[2867,4783,4784,4786,4788,4790,4792],{"class":2869,"line":2870},[2867,4785,3088],{"class":3087},[2867,4787,3091],{"class":3087},[2867,4789,3095],{"class":3094},[2867,4791,3099],{"class":3098},[2867,4793,3102],{"class":2877},[2867,4795,4796,4798,4800],{"class":2869,"line":2884},[2867,4797,3107],{"class":2917},[2867,4799,3110],{"class":2877},[2867,4801,3113],{"class":3098},[2867,4803,4804],{"class":2869,"line":2895},[2867,4805,4806],{"class":4226},"    // ~/calendar-module/components/event/Update.vue => \u003CEventUpdate />\n",[2867,4808,4809,4812,4815,4817,4819,4822,4824],{"class":2869,"line":2945},[2867,4810,4811],{"class":2877},"    {",[2867,4813,4814],{"class":2917}," path",[2867,4816,3110],{"class":2877},[2867,4818,3128],{"class":2877},[2867,4820,4821],{"class":3131},"~/calendar-module/components",[2867,4823,3135],{"class":2877},[2867,4825,4826],{"class":2877}," },\n",[2867,4828,4829],{"class":2869,"line":2955},[2867,4830,3300],{"emptyLinePlaceholder":1196},[2867,4832,4833],{"class":2869,"line":2965},[2867,4834,4835],{"class":4226},"    // ~/user-module/components/account/UserDeleteDialog.vue => \u003CUserDeleteDialog />\n",[2867,4837,4838,4840,4842,4844,4846,4849,4851,4853,4856,4858,4860],{"class":2869,"line":2975},[2867,4839,4811],{"class":2877},[2867,4841,4814],{"class":2917},[2867,4843,3110],{"class":2877},[2867,4845,3128],{"class":2877},[2867,4847,4848],{"class":3131},"~/user-module/components",[2867,4850,3135],{"class":2877},[2867,4852,3155],{"class":2877},[2867,4854,4855],{"class":2917}," pathPrefix",[2867,4857,3110],{"class":2877},[2867,4859,3152],{"class":3151},[2867,4861,4826],{"class":2877},[2867,4863,4864],{"class":2869,"line":3170},[2867,4865,3300],{"emptyLinePlaceholder":1196},[2867,4867,4868],{"class":2869,"line":3367},[2867,4869,4870],{"class":4226},"    // ~/components/special-components/Btn.vue => \u003CSpecialBtn />\n",[2867,4872,4873,4875,4877,4879,4881,4884,4886,4888,4891,4893,4895,4898,4900],{"class":2869,"line":3387},[2867,4874,4811],{"class":2877},[2867,4876,4814],{"class":2917},[2867,4878,3110],{"class":2877},[2867,4880,3128],{"class":2877},[2867,4882,4883],{"class":3131},"~/components/special-components",[2867,4885,3135],{"class":2877},[2867,4887,3155],{"class":2877},[2867,4889,4890],{"class":2917}," prefix",[2867,4892,3110],{"class":2877},[2867,4894,3128],{"class":2877},[2867,4896,4897],{"class":3131},"Special",[2867,4899,3135],{"class":2877},[2867,4901,4826],{"class":2877},[2867,4903,4904],{"class":2869,"line":3622},[2867,4905,3300],{"emptyLinePlaceholder":1196},[2867,4907,4908],{"class":2869,"line":3637},[2867,4909,4910],{"class":4226},"    // It's important that this comes last if you have overrides you wish to apply\n",[2867,4912,4913],{"class":2869,"line":3643},[2867,4914,4915],{"class":4226},"    // to sub-directories of `~/components`.\n",[2867,4917,4918],{"class":2869,"line":3649},[2867,4919,4920],{"class":4226},"    //\n",[2867,4922,4923],{"class":2869,"line":3660},[2867,4924,4925],{"class":4226},"    // ~/components/Btn.vue => \u003CBtn />\n",[2867,4927,4928],{"class":2869,"line":3669},[2867,4929,4930],{"class":4226},"    // ~/components/base/Btn.vue => \u003CBaseBtn />\n",[2867,4932,4933,4936,4938,4940],{"class":2869,"line":4719},[2867,4934,4935],{"class":2877},"    '",[2867,4937,3132],{"class":3131},[2867,4939,3135],{"class":2877},[2867,4941,3138],{"class":2877},[2867,4943,4944,4946],{"class":2869,"line":4750},[2867,4945,3165],{"class":3098},[2867,4947,3138],{"class":2877},[2867,4949,4950,4952],{"class":2869,"line":4759},[2867,4951,3173],{"class":2877},[2867,4953,3176],{"class":3098},[3051,4955,4956],{},[2853,4957,4958],{},"Any nested directories need to be added first as they are scanned in order.",[2984,4960,4962],{"id":4961},"npm-packages","npm Packages",[2853,4964,4965,4966,4972,4973,4976],{},"If you want to auto-import components from an npm package, you can use ",[3792,4967,4969],{"href":4968},"/docs/3.x/api/kit/components#addcomponent",[2864,4970,4971],{},"addComponent"," in a ",[3792,4974,4975],{"href":163},"local module"," to register them.",[4978,4979,4980,5116],"code-group",{},[2857,4981,4984],{"className":4778,"code":4982,"filename":4983,"language":3079,"meta":3080,"style":2862},"import { addComponent, defineNuxtModule } from '@nuxt/kit'\n\nexport default defineNuxtModule({\n  setup () {\n    // import { MyComponent as MyAutoImportedComponent } from 'my-npm-package'\n    addComponent({\n      name: 'MyAutoImportedComponent',\n      export: 'MyComponent',\n      filePath: 'my-npm-package',\n    })\n  },\n})\n","~/modules/register-component.ts",[2864,4985,4986,5011,5015,5027,5036,5041,5050,5066,5082,5098,5105,5110],{"__ignoreMap":2862},[2867,4987,4988,4990,4992,4995,4997,5000,5002,5004,5006,5009],{"class":2869,"line":2870},[2867,4989,3276],{"class":3087},[2867,4991,3279],{"class":2877},[2867,4993,4994],{"class":3098}," addComponent",[2867,4996,3155],{"class":2877},[2867,4998,4999],{"class":3098}," defineNuxtModule",[2867,5001,3285],{"class":2877},[2867,5003,3288],{"class":3087},[2867,5005,3128],{"class":2877},[2867,5007,5008],{"class":3131},"@nuxt/kit",[2867,5010,3295],{"class":2877},[2867,5012,5013],{"class":2869,"line":2884},[2867,5014,3300],{"emptyLinePlaceholder":1196},[2867,5016,5017,5019,5021,5023,5025],{"class":2869,"line":2895},[2867,5018,3088],{"class":3087},[2867,5020,3091],{"class":3087},[2867,5022,4999],{"class":3094},[2867,5024,3099],{"class":3098},[2867,5026,3102],{"class":2877},[2867,5028,5029,5032,5034],{"class":2869,"line":2945},[2867,5030,5031],{"class":2917},"  setup",[2867,5033,4218],{"class":2877},[2867,5035,4221],{"class":2877},[2867,5037,5038],{"class":2869,"line":2955},[2867,5039,5040],{"class":4226},"    // import { MyComponent as MyAutoImportedComponent } from 'my-npm-package'\n",[2867,5042,5043,5046,5048],{"class":2869,"line":2965},[2867,5044,5045],{"class":3094},"    addComponent",[2867,5047,3099],{"class":2917},[2867,5049,3102],{"class":2877},[2867,5051,5052,5055,5057,5059,5062,5064],{"class":2869,"line":2975},[2867,5053,5054],{"class":2917},"      name",[2867,5056,3110],{"class":2877},[2867,5058,3128],{"class":2877},[2867,5060,5061],{"class":3131},"MyAutoImportedComponent",[2867,5063,3135],{"class":2877},[2867,5065,3138],{"class":2877},[2867,5067,5068,5071,5073,5075,5078,5080],{"class":2869,"line":3170},[2867,5069,5070],{"class":2917},"      export",[2867,5072,3110],{"class":2877},[2867,5074,3128],{"class":2877},[2867,5076,5077],{"class":3131},"MyComponent",[2867,5079,3135],{"class":2877},[2867,5081,3138],{"class":2877},[2867,5083,5084,5087,5089,5091,5094,5096],{"class":2869,"line":3367},[2867,5085,5086],{"class":2917},"      filePath",[2867,5088,3110],{"class":2877},[2867,5090,3128],{"class":2877},[2867,5092,5093],{"class":3131},"my-npm-package",[2867,5095,3135],{"class":2877},[2867,5097,3138],{"class":2877},[2867,5099,5100,5103],{"class":2869,"line":3387},[2867,5101,5102],{"class":2877},"    }",[2867,5104,3176],{"class":2917},[2867,5106,5107],{"class":2869,"line":3622},[2867,5108,5109],{"class":2877},"  },\n",[2867,5111,5112,5114],{"class":2869,"line":3637},[2867,5113,3173],{"class":2877},[2867,5115,3176],{"class":3098},[2857,5117,5119],{"className":3200,"code":5118,"filename":219,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!--  the component uses the name we specified and is auto-imported  -->\n    \u003CMyAutoImportedComponent />\n  \u003C/div>\n\u003C/template>\n",[2864,5120,5121,5129,5137,5142,5150,5158],{"__ignoreMap":2862},[2867,5122,5123,5125,5127],{"class":2869,"line":2870},[2867,5124,2914],{"class":2877},[2867,5126,2918],{"class":2917},[2867,5128,2921],{"class":2877},[2867,5130,5131,5133,5135],{"class":2869,"line":2884},[2867,5132,2926],{"class":2877},[2867,5134,2929],{"class":2917},[2867,5136,2921],{"class":2877},[2867,5138,5139],{"class":2869,"line":2895},[2867,5140,5141],{"class":4226},"    \u003C!--  the component uses the name we specified and is auto-imported  -->\n",[2867,5143,5144,5146,5148],{"class":2869,"line":2945},[2867,5145,2936],{"class":2877},[2867,5147,5061],{"class":2917},[2867,5149,2942],{"class":2877},[2867,5151,5152,5154,5156],{"class":2869,"line":2955},[2867,5153,2968],{"class":2877},[2867,5155,2929],{"class":2917},[2867,5157,2921],{"class":2877},[2867,5159,5160,5162,5164],{"class":2869,"line":2965},[2867,5161,2978],{"class":2877},[2867,5163,2918],{"class":2917},[2867,5165,2921],{"class":2877},[2984,5167,5169],{"id":5168},"component-extensions","Component Extensions",[2853,5171,5172,5173,5179,5180,5183],{},"By default, any file with an extension specified in the ",[3792,5174,5176,5177],{"href":5175},"/docs/3.x/api/nuxt-config#extensions","extensions key of ",[2864,5178,233],{}," is treated as a component.\nIf you need to restrict the file extensions that should be registered as components, you can use the extended form of the components directory declaration and its ",[2864,5181,5182],{},"extensions"," key:",[2857,5185,5187],{"className":3077,"code":5186,"filename":233,"language":3079,"meta":3080,"style":2862},"export default defineNuxtConfig({\n  components: [\n    {\n      path: '~/components',\n      extensions: ['.vue'], // [!code ++]\n    },\n  ],\n})\n",[2864,5188,5189,5201,5209,5213,5227,5250,5254,5260],{"__ignoreMap":2862},[2867,5190,5191,5193,5195,5197,5199],{"class":2869,"line":2870},[2867,5192,3088],{"class":3087},[2867,5194,3091],{"class":3087},[2867,5196,3095],{"class":3094},[2867,5198,3099],{"class":3098},[2867,5200,3102],{"class":2877},[2867,5202,5203,5205,5207],{"class":2869,"line":2884},[2867,5204,3107],{"class":2917},[2867,5206,3110],{"class":2877},[2867,5208,3113],{"class":3098},[2867,5210,5211],{"class":2869,"line":2895},[2867,5212,3118],{"class":2877},[2867,5214,5215,5217,5219,5221,5223,5225],{"class":2869,"line":2945},[2867,5216,3123],{"class":2917},[2867,5218,3110],{"class":2877},[2867,5220,3128],{"class":2877},[2867,5222,3132],{"class":3131},[2867,5224,3135],{"class":2877},[2867,5226,3138],{"class":2877},[2867,5228,5230,5233,5235,5238,5240,5243,5245,5248],{"class":5229,"line":2955},[2869,3142,3143],[2867,5231,5232],{"class":2917},"      extensions",[2867,5234,3110],{"class":2877},[2867,5236,5237],{"class":3098}," [",[2867,5239,3135],{"class":2877},[2867,5241,5242],{"class":3131},".vue",[2867,5244,3135],{"class":2877},[2867,5246,5247],{"class":3098},"]",[2867,5249,3155],{"class":2877},[2867,5251,5252],{"class":2869,"line":2965},[2867,5253,3160],{"class":2877},[2867,5255,5256,5258],{"class":2869,"line":2975},[2867,5257,3165],{"class":3098},[2867,5259,3138],{"class":2877},[2867,5261,5262,5264],{"class":2869,"line":3170},[2867,5263,3173],{"class":2877},[2867,5265,3176],{"class":3098},[2984,5267,5269],{"id":5268},"client-components","Client Components",[2853,5271,5272,5273,5276],{},"If a component is meant to be rendered only client-side, you can add the ",[2864,5274,5275],{},".client"," suffix to your component.",[2857,5278,5280],{"className":2859,"code":5279,"filename":110,"language":2861,"meta":2862,"style":2862},"| components/\n--| Comments.client.vue\n",[2864,5281,5282,5288],{"__ignoreMap":2862},[2867,5283,5284,5286],{"class":2869,"line":2870},[2867,5285,2878],{"class":2877},[2867,5287,2881],{"class":2873},[2867,5289,5290,5293,5295],{"class":2869,"line":2884},[2867,5291,5292],{"class":2873},"--",[2867,5294,2878],{"class":2877},[2867,5296,5297],{"class":2873}," Comments.client.vue\n",[2857,5299,5302],{"className":3200,"code":5300,"filename":5301,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!-- this component will only be rendered on client side -->\n    \u003CComments />\n  \u003C/div>\n\u003C/template>\n","pages/example.vue",[2864,5303,5304,5312,5320,5325,5334,5342],{"__ignoreMap":2862},[2867,5305,5306,5308,5310],{"class":2869,"line":2870},[2867,5307,2914],{"class":2877},[2867,5309,2918],{"class":2917},[2867,5311,2921],{"class":2877},[2867,5313,5314,5316,5318],{"class":2869,"line":2884},[2867,5315,2926],{"class":2877},[2867,5317,2929],{"class":2917},[2867,5319,2921],{"class":2877},[2867,5321,5322],{"class":2869,"line":2895},[2867,5323,5324],{"class":4226},"    \u003C!-- this component will only be rendered on client side -->\n",[2867,5326,5327,5329,5332],{"class":2869,"line":2945},[2867,5328,2936],{"class":2877},[2867,5330,5331],{"class":2917},"Comments",[2867,5333,2942],{"class":2877},[2867,5335,5336,5338,5340],{"class":2869,"line":2955},[2867,5337,2968],{"class":2877},[2867,5339,2929],{"class":2917},[2867,5341,2921],{"class":2877},[2867,5343,5344,5346,5348],{"class":2869,"line":2965},[2867,5345,2978],{"class":2877},[2867,5347,2918],{"class":2917},[2867,5349,2921],{"class":2877},[3051,5351,5352],{},[2853,5353,5354,5355,5357],{},"This feature only works with Nuxt auto-imports and ",[2864,5356,3235],{}," imports. Explicitly importing these components from their real paths does not convert them into client-only components.",[3395,5359,5360],{},[2853,5361,5362,5364,5365,5368,5369,5372,5373,5375],{},[2864,5363,5275],{}," components are rendered only after being mounted. To access the rendered template using ",[2864,5366,5367],{},"onMounted()",", add ",[2864,5370,5371],{},"await nextTick()"," in the callback of the ",[2864,5374,5367],{}," hook.",[3777,5377,5378],{"to":441},[2853,5379,5380,5381,5383],{},"You can also achieve a similar result with the ",[2864,5382,440],{}," component.",[2984,5385,5387],{"id":5386},"server-components","Server Components",[2853,5389,5390],{},"Server components allow server-rendering individual components within your client-side apps. It's possible to use server components within Nuxt, even if you are generating a static site. That makes it possible to build complex sites that mix dynamic components, server-rendered HTML and even static chunks of markup.",[2853,5392,5393,5394,3063],{},"Server components can either be used on their own or paired with a ",[3792,5395,5397],{"href":5396},"/docs/3.x/directory-structure/components#paired-with-a-client-component","client component",[3404,5399],{"title":5400,"video-id":5401},"Watch Learn Vue video about Nuxt Server Components","u1yyXe86xJM",[5403,5404,5408],"tip",{"icon":5405,"target":5406,"to":5407},"i-lucide-newspaper","_blank","https://roe.dev/blog/nuxt-server-components",[2853,5409,5410],{},"Read Daniel Roe's guide to Nuxt Server Components.",[3690,5412,5414],{"id":5413},"standalone-server-components","Standalone server components",[2853,5416,5417],{},"Standalone server components will always be rendered on the server, also known as Islands components.",[2853,5419,5420],{},"When their props update, this will result in a network request that will update the rendered HTML in-place.",[2853,5422,5423],{},"Server components are currently experimental and in order to use them, you need to enable the 'component islands' feature in your nuxt.config:",[2857,5425,5427],{"className":4778,"code":5426,"filename":233,"language":3079,"meta":3080,"style":2862},"export default defineNuxtConfig({\n  experimental: {\n    componentIslands: true,\n  },\n})\n",[2864,5428,5429,5441,5450,5462,5466],{"__ignoreMap":2862},[2867,5430,5431,5433,5435,5437,5439],{"class":2869,"line":2870},[2867,5432,3088],{"class":3087},[2867,5434,3091],{"class":3087},[2867,5436,3095],{"class":3094},[2867,5438,3099],{"class":3098},[2867,5440,3102],{"class":2877},[2867,5442,5443,5446,5448],{"class":2869,"line":2884},[2867,5444,5445],{"class":2917},"  experimental",[2867,5447,3110],{"class":2877},[2867,5449,4221],{"class":2877},[2867,5451,5452,5455,5457,5460],{"class":2869,"line":2895},[2867,5453,5454],{"class":2917},"    componentIslands",[2867,5456,3110],{"class":2877},[2867,5458,5459],{"class":3151}," true",[2867,5461,3138],{"class":2877},[2867,5463,5464],{"class":2869,"line":2945},[2867,5465,5109],{"class":2877},[2867,5467,5468,5470],{"class":2869,"line":2955},[2867,5469,3173],{"class":2877},[2867,5471,3176],{"class":3098},[2853,5473,5474,5475,5478],{},"Now you can register server-only components with the ",[2864,5476,5477],{},".server"," suffix and use them anywhere in your application automatically.",[2857,5480,5482],{"className":2859,"code":5481,"filename":110,"language":2861,"meta":2862,"style":2862},"-| components/\n---| HighlightedMarkdown.server.vue\n",[2864,5483,5484,5492],{"__ignoreMap":2862},[2867,5485,5486,5488,5490],{"class":2869,"line":2870},[2867,5487,2874],{"class":2873},[2867,5489,2878],{"class":2877},[2867,5491,2881],{"class":2873},[2867,5493,5494,5496,5498],{"class":2869,"line":2884},[2867,5495,2887],{"class":2873},[2867,5497,2878],{"class":2877},[2867,5499,5500],{"class":2873}," HighlightedMarkdown.server.vue\n",[2857,5502,5504],{"className":3200,"code":5503,"filename":5301,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!--\n      this will automatically be rendered on the server, meaning your markdown parsing + highlighting\n      libraries are not included in your client bundle.\n     -->\n    \u003CHighlightedMarkdown markdown=\"# Headline\" />\n  \u003C/div>\n\u003C/template>\n",[2864,5505,5506,5514,5522,5527,5532,5537,5542,5563,5571],{"__ignoreMap":2862},[2867,5507,5508,5510,5512],{"class":2869,"line":2870},[2867,5509,2914],{"class":2877},[2867,5511,2918],{"class":2917},[2867,5513,2921],{"class":2877},[2867,5515,5516,5518,5520],{"class":2869,"line":2884},[2867,5517,2926],{"class":2877},[2867,5519,2929],{"class":2917},[2867,5521,2921],{"class":2877},[2867,5523,5524],{"class":2869,"line":2895},[2867,5525,5526],{"class":4226},"    \u003C!--\n",[2867,5528,5529],{"class":2869,"line":2945},[2867,5530,5531],{"class":4226},"      this will automatically be rendered on the server, meaning your markdown parsing + highlighting\n",[2867,5533,5534],{"class":2869,"line":2955},[2867,5535,5536],{"class":4226},"      libraries are not included in your client bundle.\n",[2867,5538,5539],{"class":2869,"line":2965},[2867,5540,5541],{"class":4226},"     -->\n",[2867,5543,5544,5546,5549,5552,5554,5556,5559,5561],{"class":2869,"line":2975},[2867,5545,2936],{"class":2877},[2867,5547,5548],{"class":2917},"HighlightedMarkdown",[2867,5550,5551],{"class":3212}," markdown",[2867,5553,3216],{"class":2877},[2867,5555,3219],{"class":2877},[2867,5557,5558],{"class":3131},"# Headline",[2867,5560,3219],{"class":2877},[2867,5562,2942],{"class":2877},[2867,5564,5565,5567,5569],{"class":2869,"line":3170},[2867,5566,2968],{"class":2877},[2867,5568,2929],{"class":2917},[2867,5570,2921],{"class":2877},[2867,5572,5573,5575,5577],{"class":2869,"line":3367},[2867,5574,2978],{"class":2877},[2867,5576,2918],{"class":2917},[2867,5578,2921],{"class":2877},[2853,5580,5581,5582,5586,5587,5590,5591,5594],{},"Server-only components use ",[3792,5583,5584],{"href":493},[2864,5585,492],{}," under the hood, meaning that ",[2864,5588,5589],{},"lazy"," prop and ",[2864,5592,5593],{},"#fallback"," slot are both passed down to it.",[3707,5596,5597],{},[2853,5598,5599],{},"Server components (and islands) must have a single root element. (HTML comments are considered elements as well.)",[3707,5601,5602],{},[2853,5603,5604],{},"Props are passed to server components via URL query parameters, and are therefore limited by the possible length of a URL, so be careful not to pass enormous amounts of data to server components via props.",[3707,5606,5607],{},[2853,5608,5609],{},"Be careful when nesting islands within other islands as each island adds some extra overhead.",[3707,5611,5612],{},[2853,5613,5614],{},"Most features for server-only components and island components, such as slots and client components, are only available for single file components.",[3719,5616,5618],{"id":5617},"client-components-within-server-components","Client components within server components",[3051,5620,5621],{},[2853,5622,5623,5624,5627],{},"This feature needs ",[2864,5625,5626],{},"experimental.componentIslands.selectiveClient"," within your configuration to be true.",[2853,5629,5630,5631,5634],{},"You can partially hydrate a component by setting a ",[2864,5632,5633],{},"nuxt-client"," attribute on the component you wish to be loaded client-side.",[2857,5636,5639],{"className":3200,"code":5637,"filename":5638,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CHighlightedMarkdown markdown=\"# Headline\" />\n    \u003C!-- Counter will be loaded and hydrated client-side -->\n    \u003CCounter\n      nuxt-client\n      :count=\"5\"\n    />\n  \u003C/div>\n\u003C/template>\n","components/ServerWithClient.vue",[2864,5640,5641,5649,5657,5675,5680,5687,5692,5706,5710,5718],{"__ignoreMap":2862},[2867,5642,5643,5645,5647],{"class":2869,"line":2870},[2867,5644,2914],{"class":2877},[2867,5646,2918],{"class":2917},[2867,5648,2921],{"class":2877},[2867,5650,5651,5653,5655],{"class":2869,"line":2884},[2867,5652,2926],{"class":2877},[2867,5654,2929],{"class":2917},[2867,5656,2921],{"class":2877},[2867,5658,5659,5661,5663,5665,5667,5669,5671,5673],{"class":2869,"line":2895},[2867,5660,2936],{"class":2877},[2867,5662,5548],{"class":2917},[2867,5664,5551],{"class":3212},[2867,5666,3216],{"class":2877},[2867,5668,3219],{"class":2877},[2867,5670,5558],{"class":3131},[2867,5672,3219],{"class":2877},[2867,5674,2942],{"class":2877},[2867,5676,5677],{"class":2869,"line":2945},[2867,5678,5679],{"class":4226},"    \u003C!-- Counter will be loaded and hydrated client-side -->\n",[2867,5681,5682,5684],{"class":2869,"line":2955},[2867,5683,2936],{"class":2877},[2867,5685,5686],{"class":2917},"Counter\n",[2867,5688,5689],{"class":2869,"line":2965},[2867,5690,5691],{"class":3212},"      nuxt-client\n",[2867,5693,5694,5697,5699,5701,5704],{"class":2869,"line":2975},[2867,5695,5696],{"class":3212},"      :count",[2867,5698,3216],{"class":2877},[2867,5700,3219],{"class":2877},[2867,5702,5703],{"class":3131},"5",[2867,5705,3619],{"class":2877},[2867,5707,5708],{"class":2869,"line":3170},[2867,5709,4374],{"class":2877},[2867,5711,5712,5714,5716],{"class":2869,"line":3367},[2867,5713,2968],{"class":2877},[2867,5715,2929],{"class":2917},[2867,5717,2921],{"class":2877},[2867,5719,5720,5722,5724],{"class":2869,"line":3387},[2867,5721,2978],{"class":2877},[2867,5723,2918],{"class":2917},[2867,5725,2921],{"class":2877},[3051,5727,5728],{},[2853,5729,5730,5731,5734,5735,5738],{},"This only works within a server component. Slots for client components are working only with ",[2864,5732,5733],{},"experimental.componentIsland.selectiveClient"," set to ",[2864,5736,5737],{},"'deep'"," and since they are rendered server-side, they are not interactive once client-side.",[3719,5740,5742],{"id":5741},"server-component-context","Server Component Context",[2853,5744,5745,5746,5748,5749,5752],{},"When rendering a server-only or island component, ",[2864,5747,492],{}," makes a fetch request which comes back with a ",[2864,5750,5751],{},"NuxtIslandResponse",". (This is an internal request if rendered on the server, or a request that you can see in the network tab if it's rendering on client-side navigation.)",[2853,5754,5755],{},"This means:",[4504,5757,5758,5763,5766,5774],{},[4470,5759,5760,5761,3063],{},"A new Vue app will be created server-side to create the ",[2864,5762,5751],{},[4470,5764,5765],{},"A new 'island context' will be created while rendering the component.",[4470,5767,5768,5769,5773],{},"You can't access the 'island context' from the rest of your app and you can't access the context of the rest of your app from the island component. In other words, the server component or island is ",[5770,5771,5772],"em",{},"isolated"," from the rest of your app.",[4470,5775,5776,5777,5780],{},"Your plugins will run again when rendering the island, unless they have ",[2864,5778,5779],{},"env: { islands: false }"," set (which you can do in an object-syntax plugin).",[3395,5782,5783],{},[2853,5784,5785],{},"Route middleware does not run when rendering island components. Middleware is a routing concept that applies to pages, not components, and is not designed to control component rendering.",[2853,5787,5788,5789,5792],{},"Within an island component, you can access its island context through ",[2864,5790,5791],{},"nuxtApp.ssrContext.islandContext",". Note that while island components are still marked as experimental, the format of this context may change.",[3051,5794,5795],{},[2853,5796,5797,5798,5801,5802],{},"Slots can be interactive and are wrapped within a ",[2864,5799,5800],{},"\u003Cdiv>"," with ",[2864,5803,5804],{},"display: contents;",[3690,5806,5808],{"id":5807},"paired-with-a-client-component","Paired with a Client component",[2853,5810,5811,5812,5814,5815,5817],{},"In this case, the ",[2864,5813,5477],{}," + ",[2864,5816,5275],{}," components are two 'halves' of a component and can be used in advanced use cases for separate implementations of a component on server and client side.",[2857,5819,5821],{"className":2859,"code":5820,"filename":110,"language":2861,"meta":2862,"style":2862},"-| components/\n---| Comments.client.vue\n---| Comments.server.vue\n",[2864,5822,5823,5831,5839],{"__ignoreMap":2862},[2867,5824,5825,5827,5829],{"class":2869,"line":2870},[2867,5826,2874],{"class":2873},[2867,5828,2878],{"class":2877},[2867,5830,2881],{"class":2873},[2867,5832,5833,5835,5837],{"class":2869,"line":2884},[2867,5834,2887],{"class":2873},[2867,5836,2878],{"class":2877},[2867,5838,5297],{"class":2873},[2867,5840,5841,5843,5845],{"class":2869,"line":2895},[2867,5842,2887],{"class":2873},[2867,5844,2878],{"class":2877},[2867,5846,5847],{"class":2873}," Comments.server.vue\n",[2857,5849,5851],{"className":3200,"code":5850,"filename":5301,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003C!-- this component will render Comments.server on the server then Comments.client once mounted in the browser -->\n    \u003CComments />\n  \u003C/div>\n\u003C/template>\n",[2864,5852,5853,5861,5869,5874,5882,5890],{"__ignoreMap":2862},[2867,5854,5855,5857,5859],{"class":2869,"line":2870},[2867,5856,2914],{"class":2877},[2867,5858,2918],{"class":2917},[2867,5860,2921],{"class":2877},[2867,5862,5863,5865,5867],{"class":2869,"line":2884},[2867,5864,2926],{"class":2877},[2867,5866,2929],{"class":2917},[2867,5868,2921],{"class":2877},[2867,5870,5871],{"class":2869,"line":2895},[2867,5872,5873],{"class":4226},"    \u003C!-- this component will render Comments.server on the server then Comments.client once mounted in the browser -->\n",[2867,5875,5876,5878,5880],{"class":2869,"line":2945},[2867,5877,2936],{"class":2877},[2867,5879,5331],{"class":2917},[2867,5881,2942],{"class":2877},[2867,5883,5884,5886,5888],{"class":2869,"line":2955},[2867,5885,2968],{"class":2877},[2867,5887,2929],{"class":2917},[2867,5889,2921],{"class":2877},[2867,5891,5892,5894,5896],{"class":2869,"line":2965},[2867,5893,2978],{"class":2877},[2867,5895,2918],{"class":2917},[2867,5897,2921],{"class":2877},[2984,5899,5901],{"id":5900},"built-in-nuxt-components","Built-In Nuxt Components",[2853,5903,5904,5905,3946,5907,5909],{},"There are a number of components that Nuxt provides, including ",[2864,5906,440],{},[2864,5908,444],{},". You can read more about them in the API documentation.",[3777,5911],{"to":430},[2984,5913,5915],{"id":5914},"library-authors","Library Authors",[2853,5917,5918],{},"Making Vue component libraries with automatic tree-shaking and component registration is super easy. ✨",[2853,5920,5921,5922,5928,5929,5931],{},"You can use the ",[3792,5923,5925],{"href":5924},"/docs/3.x/api/kit/components#addcomponentsdir",[2864,5926,5927],{},"addComponentsDir"," method provided from the ",[2864,5930,5008],{}," to register your components directory in your Nuxt module.",[2853,5933,5934],{},"Imagine a directory structure like this:",[2857,5936,5938],{"className":2859,"code":5937,"filename":110,"language":2861,"meta":2862,"style":2862},"-| node_modules/\n---| awesome-ui/\n-----| components/\n-------| Alert.vue\n-------| Button.vue\n-----| nuxt.ts\n-| pages/\n---| index.vue\n-| nuxt.config.ts\n",[2864,5939,5940,5949,5958,5966,5975,5983,5992,6001,6010],{"__ignoreMap":2862},[2867,5941,5942,5944,5946],{"class":2869,"line":2870},[2867,5943,2874],{"class":2873},[2867,5945,2878],{"class":2877},[2867,5947,5948],{"class":2873}," node_modules/\n",[2867,5950,5951,5953,5955],{"class":2869,"line":2884},[2867,5952,2887],{"class":2873},[2867,5954,2878],{"class":2877},[2867,5956,5957],{"class":2873}," awesome-ui/\n",[2867,5959,5960,5962,5964],{"class":2869,"line":2895},[2867,5961,3017],{"class":2873},[2867,5963,2878],{"class":2877},[2867,5965,2881],{"class":2873},[2867,5967,5968,5970,5972],{"class":2869,"line":2945},[2867,5969,3027],{"class":2873},[2867,5971,2878],{"class":2877},[2867,5973,5974],{"class":2873}," Alert.vue\n",[2867,5976,5977,5979,5981],{"class":2869,"line":2955},[2867,5978,3027],{"class":2873},[2867,5980,2878],{"class":2877},[2867,5982,3032],{"class":2873},[2867,5984,5985,5987,5989],{"class":2869,"line":2965},[2867,5986,3017],{"class":2873},[2867,5988,2878],{"class":2877},[2867,5990,5991],{"class":2873}," nuxt.ts\n",[2867,5993,5994,5996,5998],{"class":2869,"line":2975},[2867,5995,2874],{"class":2873},[2867,5997,2878],{"class":2877},[2867,5999,6000],{"class":2873}," pages/\n",[2867,6002,6003,6005,6007],{"class":2869,"line":3170},[2867,6004,2887],{"class":2873},[2867,6006,2878],{"class":2877},[2867,6008,6009],{"class":2873}," index.vue\n",[2867,6011,6012,6014,6016],{"class":2869,"line":3367},[2867,6013,2874],{"class":2873},[2867,6015,2878],{"class":2877},[2867,6017,6018],{"class":2873}," nuxt.config.ts\n",[2853,6020,6021,6022,6025,6026,6028],{},"Then in ",[2864,6023,6024],{},"awesome-ui/nuxt.ts"," you can use the ",[2864,6027,5927],{}," hook:",[2857,6030,6032],{"className":4778,"code":6031,"language":3079,"meta":3080,"style":2862},"import { addComponentsDir, createResolver, defineNuxtModule } from '@nuxt/kit'\n\nexport default defineNuxtModule({\n  setup () {\n    const resolver = createResolver(import.meta.url)\n\n    // Add ./components dir to the list\n    addComponentsDir({\n      path: resolver.resolve('./components'),\n      prefix: 'awesome',\n    })\n  },\n})\n",[2864,6033,6034,6062,6066,6078,6086,6114,6118,6123,6132,6159,6175,6181,6185],{"__ignoreMap":2862},[2867,6035,6036,6038,6040,6043,6045,6048,6050,6052,6054,6056,6058,6060],{"class":2869,"line":2870},[2867,6037,3276],{"class":3087},[2867,6039,3279],{"class":2877},[2867,6041,6042],{"class":3098}," addComponentsDir",[2867,6044,3155],{"class":2877},[2867,6046,6047],{"class":3098}," createResolver",[2867,6049,3155],{"class":2877},[2867,6051,4999],{"class":3098},[2867,6053,3285],{"class":2877},[2867,6055,3288],{"class":3087},[2867,6057,3128],{"class":2877},[2867,6059,5008],{"class":3131},[2867,6061,3295],{"class":2877},[2867,6063,6064],{"class":2869,"line":2884},[2867,6065,3300],{"emptyLinePlaceholder":1196},[2867,6067,6068,6070,6072,6074,6076],{"class":2869,"line":2895},[2867,6069,3088],{"class":3087},[2867,6071,3091],{"class":3087},[2867,6073,4999],{"class":3094},[2867,6075,3099],{"class":3098},[2867,6077,3102],{"class":2877},[2867,6079,6080,6082,6084],{"class":2869,"line":2945},[2867,6081,5031],{"class":2917},[2867,6083,4218],{"class":2877},[2867,6085,4221],{"class":2877},[2867,6087,6088,6091,6094,6096,6098,6100,6102,6104,6107,6109,6112],{"class":2869,"line":2955},[2867,6089,6090],{"class":3212},"    const",[2867,6092,6093],{"class":3098}," resolver",[2867,6095,4240],{"class":2877},[2867,6097,6047],{"class":3094},[2867,6099,3099],{"class":2917},[2867,6101,3276],{"class":3087},[2867,6103,3063],{"class":2877},[2867,6105,6106],{"class":3098},"meta",[2867,6108,3063],{"class":2877},[2867,6110,6111],{"class":3098},"url",[2867,6113,3176],{"class":2917},[2867,6115,6116],{"class":2869,"line":2965},[2867,6117,3300],{"emptyLinePlaceholder":1196},[2867,6119,6120],{"class":2869,"line":2975},[2867,6121,6122],{"class":4226},"    // Add ./components dir to the list\n",[2867,6124,6125,6128,6130],{"class":2869,"line":3170},[2867,6126,6127],{"class":3094},"    addComponentsDir",[2867,6129,3099],{"class":2917},[2867,6131,3102],{"class":2877},[2867,6133,6134,6136,6138,6140,6142,6145,6147,6149,6152,6154,6157],{"class":2869,"line":3367},[2867,6135,3123],{"class":2917},[2867,6137,3110],{"class":2877},[2867,6139,6093],{"class":3098},[2867,6141,3063],{"class":2877},[2867,6143,6144],{"class":3094},"resolve",[2867,6146,3099],{"class":2917},[2867,6148,3135],{"class":2877},[2867,6150,6151],{"class":3131},"./components",[2867,6153,3135],{"class":2877},[2867,6155,6156],{"class":2917},")",[2867,6158,3138],{"class":2877},[2867,6160,6161,6164,6166,6168,6171,6173],{"class":2869,"line":3387},[2867,6162,6163],{"class":2917},"      prefix",[2867,6165,3110],{"class":2877},[2867,6167,3128],{"class":2877},[2867,6169,6170],{"class":3131},"awesome",[2867,6172,3135],{"class":2877},[2867,6174,3138],{"class":2877},[2867,6176,6177,6179],{"class":2869,"line":3622},[2867,6178,5102],{"class":2877},[2867,6180,3176],{"class":2917},[2867,6182,6183],{"class":2869,"line":3637},[2867,6184,5109],{"class":2877},[2867,6186,6187,6189],{"class":2869,"line":3643},[2867,6188,3173],{"class":2877},[2867,6190,3176],{"class":3098},[2853,6192,6193,6194,6197],{},"That's it! Now in your project, you can import your UI library as a Nuxt module in your ",[2864,6195,6196],{},"nuxt.config"," file:",[2857,6199,6201],{"className":4778,"code":6200,"filename":233,"language":3079,"meta":3080,"style":2862},"export default defineNuxtConfig({\n  modules: ['awesome-ui/nuxt'],\n})\n",[2864,6202,6203,6215,6235],{"__ignoreMap":2862},[2867,6204,6205,6207,6209,6211,6213],{"class":2869,"line":2870},[2867,6206,3088],{"class":3087},[2867,6208,3091],{"class":3087},[2867,6210,3095],{"class":3094},[2867,6212,3099],{"class":3098},[2867,6214,3102],{"class":2877},[2867,6216,6217,6220,6222,6224,6226,6229,6231,6233],{"class":2869,"line":2884},[2867,6218,6219],{"class":2917},"  modules",[2867,6221,3110],{"class":2877},[2867,6223,5237],{"class":3098},[2867,6225,3135],{"class":2877},[2867,6227,6228],{"class":3131},"awesome-ui/nuxt",[2867,6230,3135],{"class":2877},[2867,6232,5247],{"class":3098},[2867,6234,3138],{"class":2877},[2867,6236,6237,6239],{"class":2869,"line":2895},[2867,6238,3173],{"class":2877},[2867,6240,3176],{"class":3098},[2853,6242,6243,6244,6247,6248,3110],{},"... and directly use the module components (prefixed with ",[2864,6245,6246],{},"awesome-",") in our ",[2864,6249,3246],{},[2857,6251,6253],{"className":3200,"code":6252,"language":3201,"meta":2862,"style":2862},"\u003Ctemplate>\n  \u003Cdiv>\n    My \u003CAwesomeButton>UI button\u003C/AwesomeButton>!\n    \u003Cawesome-alert>Here's an alert!\u003C/awesome-alert>\n  \u003C/div>\n\u003C/template>\n",[2864,6254,6255,6263,6271,6295,6313,6321],{"__ignoreMap":2862},[2867,6256,6257,6259,6261],{"class":2869,"line":2870},[2867,6258,2914],{"class":2877},[2867,6260,2918],{"class":2917},[2867,6262,2921],{"class":2877},[2867,6264,6265,6267,6269],{"class":2869,"line":2884},[2867,6266,2926],{"class":2877},[2867,6268,2929],{"class":2917},[2867,6270,2921],{"class":2877},[2867,6272,6273,6276,6278,6281,6283,6286,6288,6290,6292],{"class":2869,"line":2895},[2867,6274,6275],{"class":3098},"    My ",[2867,6277,2914],{"class":2877},[2867,6279,6280],{"class":2917},"AwesomeButton",[2867,6282,3227],{"class":2877},[2867,6284,6285],{"class":3098},"UI button",[2867,6287,2978],{"class":2877},[2867,6289,6280],{"class":2917},[2867,6291,3227],{"class":2877},[2867,6293,6294],{"class":3098},"!\n",[2867,6296,6297,6299,6302,6304,6307,6309,6311],{"class":2869,"line":2945},[2867,6298,2936],{"class":2877},[2867,6300,6301],{"class":2917},"awesome-alert",[2867,6303,3227],{"class":2877},[2867,6305,6306],{"class":3098},"Here's an alert!",[2867,6308,2978],{"class":2877},[2867,6310,6301],{"class":2917},[2867,6312,2921],{"class":2877},[2867,6314,6315,6317,6319],{"class":2869,"line":2955},[2867,6316,2968],{"class":2877},[2867,6318,2929],{"class":2917},[2867,6320,2921],{"class":2877},[2867,6322,6323,6325,6327],{"class":2869,"line":2965},[2867,6324,2978],{"class":2877},[2867,6326,2918],{"class":2917},[2867,6328,2921],{"class":2877},[2853,6330,6331,6332,3063],{},"It will automatically import the components only if used and also support HMR when updating your components in ",[2864,6333,6334],{},"node_modules/awesome-ui/components/",[6336,6337],"link-example",{"to":923},[6339,6340,6341],"style",{},"html pre.shiki code .s52Pk, html code.shiki .s52Pk{--shiki-light:#E2931D;--shiki-default:#E2931D;--shiki-dark:#FFCB6B}html pre.shiki code .sDfIl, html code.shiki .sDfIl{--shiki-light:#39ADB5;--shiki-default:#39ADB5;--shiki-dark:#89DDFF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sRlkE, html code.shiki .sRlkE{--shiki-light:#E53935;--shiki-default:#E53935;--shiki-dark:#F07178}html pre.shiki code .s8R28, html code.shiki .s8R28{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#39ADB5;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .s3cPz, html code.shiki .s3cPz{--shiki-light:#6182B8;--shiki-default:#6182B8;--shiki-dark:#82AAFF}html pre.shiki code .sZSNi, html code.shiki .sZSNi{--shiki-light:#90A4AE;--shiki-default:#90A4AE;--shiki-dark:#BABED8}html pre.shiki code .sGFVr, html code.shiki .sGFVr{--shiki-light:#91B859;--shiki-default:#91B859;--shiki-dark:#C3E88D}html pre.shiki code .sbKd-, html code.shiki .sbKd-{--shiki-light:#FF5370;--shiki-default:#FF5370;--shiki-dark:#FF9CAC}html pre.shiki code .smZ93, html code.shiki .smZ93{--shiki-light:#9C3EDA;--shiki-default:#9C3EDA;--shiki-dark:#C792EA}html pre.shiki code .sWuyu, html code.shiki .sWuyu{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#90A4AE;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}",{"title":2862,"searchDepth":2884,"depth":2884,"links":6343},[6344,6345,6346,6347,6352,6353,6354,6355,6356,6357,6361,6362],{"id":2986,"depth":2884,"text":2987},{"id":3193,"depth":2884,"text":3194},{"id":3473,"depth":2884,"text":3474},{"id":3678,"depth":2884,"text":3679,"children":6348},[6349,6350,6351],{"id":3692,"depth":2895,"text":3693},{"id":4314,"depth":2895,"text":4315},{"id":4461,"depth":2895,"text":4462},{"id":4532,"depth":2884,"text":4533},{"id":4768,"depth":2884,"text":4769},{"id":4961,"depth":2884,"text":4962},{"id":5168,"depth":2884,"text":5169},{"id":5268,"depth":2884,"text":5269},{"id":5386,"depth":2884,"text":5387,"children":6358},[6359,6360],{"id":5413,"depth":2895,"text":5414},{"id":5807,"depth":2895,"text":5808},{"id":5900,"depth":2884,"text":5901},{"id":5914,"depth":2884,"text":5915},"The components/ directory is where you put all your Vue components.","md",{"head":6366},{"title":6367},"components/",{"icon":135},{"title":132,"description":6363},"CurfJjvxwOzpaurvouKVBJYs7nljtVs5-Th6E31-Z2Q",[6372,6374],{"title":127,"path":128,"stem":129,"description":6373,"icon":130,"children":-1},"The assets/ directory is used to add all the website's assets that the build tool will process.",{"title":137,"path":138,"stem":139,"description":6375,"icon":140,"children":-1},"Use the composables/ directory to auto-import your Vue composables into your application.",1772463083556]