[{"data":1,"prerenderedAt":5561},["ShallowReactive",2],{"$fGCo9l1hMtNdUiA6QzdUX5X3kLqaWcC5t2kdz4LrvCvc":3,"versions":2028,"-docs-3-x-directory-structure-components":2032,"-docs-3-x-directory-structure-components-surround":5556},[4,1120,1939],{"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,1403,1769,1846,1868,1902],{"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,1318,1328,1353,1369],{"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,1312,1315],{"title":295,"path":1310,"stem":1311,"titleTemplate":6},"/docs/4.x/guide/best-practices/hydration","docs/4.x/3.guide/2.best-practices/hydration",{"title":299,"path":1313,"stem":1314,"titleTemplate":6},"/docs/4.x/guide/best-practices/performance","docs/4.x/3.guide/2.best-practices/performance",{"title":303,"path":1316,"stem":1317,"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":1319,"stem":1320,"children":1321,"page":108},"/docs/4.x/guide/ai","docs/4.x/3.guide/3.ai",[1322,1325],{"title":314,"path":1323,"stem":1324,"titleTemplate":6},"/docs/4.x/guide/ai/mcp","docs/4.x/3.guide/3.ai/1.mcp",{"title":318,"path":1326,"stem":1327,"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":1329,"stem":1330,"children":1331,"page":108},"/docs/4.x/guide/modules","docs/4.x/3.guide/4.modules",[1332,1335,1338,1341,1344,1347,1350],{"title":329,"path":1333,"stem":1334,"titleTemplate":6},"/docs/4.x/guide/modules/getting-started","docs/4.x/3.guide/4.modules/1.getting-started",{"title":333,"path":1336,"stem":1337,"titleTemplate":6},"/docs/4.x/guide/modules/module-anatomy","docs/4.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":1339,"stem":1340,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-basics","docs/4.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":1342,"stem":1343,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-advanced","docs/4.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":1345,"stem":1346,"titleTemplate":6},"/docs/4.x/guide/modules/testing","docs/4.x/3.guide/4.modules/5.testing",{"title":349,"path":1348,"stem":1349,"titleTemplate":6},"/docs/4.x/guide/modules/best-practices","docs/4.x/3.guide/4.modules/6.best-practices",{"title":353,"path":1351,"stem":1352,"titleTemplate":6},"/docs/4.x/guide/modules/ecosystem","docs/4.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":1354,"stem":1355,"children":1356,"page":108},"/docs/4.x/guide/recipes","docs/4.x/3.guide/5.recipes",[1357,1360,1363,1366],{"title":364,"path":1358,"stem":1359,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-routing","docs/4.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":1361,"stem":1362,"titleTemplate":6},"/docs/4.x/guide/recipes/vite-plugin","docs/4.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":1364,"stem":1365,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-usefetch","docs/4.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":1367,"stem":1368,"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":1370,"stem":1371,"children":1372,"page":108},"/docs/4.x/guide/going-further","docs/4.x/3.guide/6.going-further",[1373,1376,1379,1382,1385,1388,1391,1394,1397,1400],{"title":387,"path":1374,"stem":1375,"titleTemplate":6},"/docs/4.x/guide/going-further/events","docs/4.x/3.guide/6.going-further/1.events",{"title":391,"path":1377,"stem":1378,"titleTemplate":6},"/docs/4.x/guide/going-further/experimental-features","docs/4.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":1380,"stem":1381,"titleTemplate":6},"/docs/4.x/guide/going-further/features","docs/4.x/3.guide/6.going-further/1.features",{"title":399,"path":1383,"stem":1384,"titleTemplate":6},"/docs/4.x/guide/going-further/runtime-config","docs/4.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":1386,"stem":1387,"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":1389,"stem":1390,"titleTemplate":6},"/docs/4.x/guide/going-further/hooks","docs/4.x/3.guide/6.going-further/2.hooks",{"title":411,"path":1392,"stem":1393,"titleTemplate":6},"/docs/4.x/guide/going-further/kit","docs/4.x/3.guide/6.going-further/4.kit",{"title":415,"path":1395,"stem":1396,"titleTemplate":6},"/docs/4.x/guide/going-further/nuxt-app","docs/4.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":1398,"stem":1399,"titleTemplate":6},"/docs/4.x/guide/going-further/layers","docs/4.x/3.guide/6.going-further/7.layers",{"title":423,"path":1401,"stem":1402,"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":1404,"stem":1405,"children":1406,"page":108},"/docs/4.x/api","docs/4.x/4.api",[1407,1460,1555,1646,1698,1756,1766],{"title":434,"titleTemplate":435,"icon":324,"path":1408,"stem":1409,"children":1410,"page":108},"/docs/4.x/api/components","docs/4.x/4.api/1.components",[1411,1414,1417,1420,1423,1426,1429,1432,1436,1439,1442,1445,1448,1451,1454,1457],{"title":440,"path":1412,"stem":1413,"titleTemplate":6},"/docs/4.x/api/components/client-only","docs/4.x/4.api/1.components/1.client-only",{"title":444,"path":1415,"stem":1416,"titleTemplate":6},"/docs/4.x/api/components/dev-only","docs/4.x/4.api/1.components/1.dev-only",{"title":448,"path":1418,"stem":1419,"titleTemplate":6},"/docs/4.x/api/components/nuxt-client-fallback","docs/4.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":1421,"stem":1422,"titleTemplate":6},"/docs/4.x/api/components/nuxt-picture","docs/4.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":1424,"stem":1425,"titleTemplate":6},"/docs/4.x/api/components/teleports","docs/4.x/4.api/1.components/11.teleports",{"title":460,"path":1427,"stem":1428,"titleTemplate":6},"/docs/4.x/api/components/nuxt-route-announcer","docs/4.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":1430,"stem":1431,"titleTemplate":6},"/docs/4.x/api/components/nuxt-time","docs/4.x/4.api/1.components/13.nuxt-time",{"title":1433,"path":1434,"stem":1435,"titleTemplate":6},"\u003CNuxtAnnouncer>","/docs/4.x/api/components/nuxt-announcer","docs/4.x/4.api/1.components/14.nuxt-announcer",{"title":468,"path":1437,"stem":1438,"titleTemplate":6},"/docs/4.x/api/components/nuxt-page","docs/4.x/4.api/1.components/2.nuxt-page",{"title":472,"path":1440,"stem":1441,"titleTemplate":6},"/docs/4.x/api/components/nuxt-layout","docs/4.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":1443,"stem":1444,"titleTemplate":6},"/docs/4.x/api/components/nuxt-link","docs/4.x/4.api/1.components/4.nuxt-link",{"title":480,"path":1446,"stem":1447,"titleTemplate":6},"/docs/4.x/api/components/nuxt-loading-indicator","docs/4.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":1449,"stem":1450,"titleTemplate":6},"/docs/4.x/api/components/nuxt-error-boundary","docs/4.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":1452,"stem":1453,"titleTemplate":6},"/docs/4.x/api/components/nuxt-welcome","docs/4.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":1455,"stem":1456,"titleTemplate":6},"/docs/4.x/api/components/nuxt-island","docs/4.x/4.api/1.components/8.nuxt-island",{"title":496,"path":1458,"stem":1459,"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":1461,"stem":1462,"children":1463,"page":108},"/docs/4.x/api/composables","docs/4.x/4.api/2.composables",[1464,1467,1471,1474,1477,1480,1483,1486,1489,1492,1495,1498,1501,1504,1507,1510,1513,1516,1519,1522,1525,1528,1531,1534,1537,1540,1543,1546,1549,1552],{"title":507,"path":1465,"stem":1466,"titleTemplate":6},"/docs/4.x/api/composables/on-prehydrate","docs/4.x/4.api/2.composables/on-prehydrate",{"title":1468,"path":1469,"stem":1470,"titleTemplate":6},"useAnnouncer","/docs/4.x/api/composables/use-announcer","docs/4.x/4.api/2.composables/use-announcer",{"title":511,"path":1472,"stem":1473,"titleTemplate":6},"/docs/4.x/api/composables/use-app-config","docs/4.x/4.api/2.composables/use-app-config",{"title":515,"path":1475,"stem":1476,"titleTemplate":6},"/docs/4.x/api/composables/use-async-data","docs/4.x/4.api/2.composables/use-async-data",{"title":519,"path":1478,"stem":1479,"titleTemplate":6},"/docs/4.x/api/composables/use-cookie","docs/4.x/4.api/2.composables/use-cookie",{"title":523,"path":1481,"stem":1482,"titleTemplate":6},"/docs/4.x/api/composables/use-error","docs/4.x/4.api/2.composables/use-error",{"title":527,"path":1484,"stem":1485,"titleTemplate":6},"/docs/4.x/api/composables/use-fetch","docs/4.x/4.api/2.composables/use-fetch",{"title":531,"path":1487,"stem":1488,"titleTemplate":6},"/docs/4.x/api/composables/use-head","docs/4.x/4.api/2.composables/use-head",{"title":535,"path":1490,"stem":1491,"titleTemplate":6},"/docs/4.x/api/composables/use-head-safe","docs/4.x/4.api/2.composables/use-head-safe",{"title":539,"path":1493,"stem":1494,"titleTemplate":6},"/docs/4.x/api/composables/use-hydration","docs/4.x/4.api/2.composables/use-hydration",{"title":543,"path":1496,"stem":1497,"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":1499,"stem":1500,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-fetch","docs/4.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":1502,"stem":1503,"titleTemplate":6},"/docs/4.x/api/composables/use-loading-indicator","docs/4.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":1505,"stem":1506,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-app","docs/4.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":1508,"stem":1509,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-data","docs/4.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":1511,"stem":1512,"titleTemplate":6},"/docs/4.x/api/composables/use-preview-mode","docs/4.x/4.api/2.composables/use-preview-mode",{"title":567,"path":1514,"stem":1515,"titleTemplate":6},"/docs/4.x/api/composables/use-request-event","docs/4.x/4.api/2.composables/use-request-event",{"title":571,"path":1517,"stem":1518,"titleTemplate":6},"/docs/4.x/api/composables/use-request-fetch","docs/4.x/4.api/2.composables/use-request-fetch",{"title":575,"path":1520,"stem":1521,"titleTemplate":6},"/docs/4.x/api/composables/use-request-header","docs/4.x/4.api/2.composables/use-request-header",{"title":579,"path":1523,"stem":1524,"titleTemplate":6},"/docs/4.x/api/composables/use-request-headers","docs/4.x/4.api/2.composables/use-request-headers",{"title":583,"path":1526,"stem":1527,"titleTemplate":6},"/docs/4.x/api/composables/use-request-url","docs/4.x/4.api/2.composables/use-request-url",{"title":587,"path":1529,"stem":1530,"titleTemplate":6},"/docs/4.x/api/composables/use-response-header","docs/4.x/4.api/2.composables/use-response-header",{"title":591,"path":1532,"stem":1533,"titleTemplate":6},"/docs/4.x/api/composables/use-route","docs/4.x/4.api/2.composables/use-route",{"title":595,"path":1535,"stem":1536,"titleTemplate":6},"/docs/4.x/api/composables/use-route-announcer","docs/4.x/4.api/2.composables/use-route-announcer",{"title":599,"path":1538,"stem":1539,"titleTemplate":6},"/docs/4.x/api/composables/use-router","docs/4.x/4.api/2.composables/use-router",{"title":603,"path":1541,"stem":1542,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-config","docs/4.x/4.api/2.composables/use-runtime-config",{"title":607,"path":1544,"stem":1545,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-hook","docs/4.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":1547,"stem":1548,"titleTemplate":6},"/docs/4.x/api/composables/use-seo-meta","docs/4.x/4.api/2.composables/use-seo-meta",{"title":615,"path":1550,"stem":1551,"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":1553,"stem":1554,"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":1556,"stem":1557,"children":1558,"page":108},"/docs/4.x/api/utils","docs/4.x/4.api/3.utils",[1559,1562,1565,1568,1571,1574,1577,1580,1583,1586,1589,1592,1595,1598,1601,1604,1607,1610,1613,1616,1619,1622,1625,1628,1631,1634,1637,1640,1643],{"title":630,"path":1560,"stem":1561,"titleTemplate":6},"/docs/4.x/api/utils/dollarfetch","docs/4.x/4.api/3.utils/$fetch",{"title":634,"path":1563,"stem":1564,"titleTemplate":6},"/docs/4.x/api/utils/abort-navigation","docs/4.x/4.api/3.utils/abort-navigation",{"title":638,"path":1566,"stem":1567,"titleTemplate":6},"/docs/4.x/api/utils/add-route-middleware","docs/4.x/4.api/3.utils/add-route-middleware",{"title":642,"path":1569,"stem":1570,"titleTemplate":6},"/docs/4.x/api/utils/call-once","docs/4.x/4.api/3.utils/call-once",{"title":646,"path":1572,"stem":1573,"titleTemplate":6},"/docs/4.x/api/utils/clear-error","docs/4.x/4.api/3.utils/clear-error",{"title":650,"path":1575,"stem":1576,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-data","docs/4.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":1578,"stem":1579,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-state","docs/4.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":1581,"stem":1582,"titleTemplate":6},"/docs/4.x/api/utils/create-error","docs/4.x/4.api/3.utils/create-error",{"title":662,"path":1584,"stem":1585,"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":1587,"stem":1588,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-component","docs/4.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":1590,"stem":1591,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-plugin","docs/4.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":1593,"stem":1594,"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":1596,"stem":1597,"titleTemplate":6},"/docs/4.x/api/utils/define-page-meta","docs/4.x/4.api/3.utils/define-page-meta",{"title":682,"path":1599,"stem":1600,"titleTemplate":6},"/docs/4.x/api/utils/define-route-rules","docs/4.x/4.api/3.utils/define-route-rules",{"title":686,"path":1602,"stem":1603,"titleTemplate":6},"/docs/4.x/api/utils/navigate-to","docs/4.x/4.api/3.utils/navigate-to",{"title":690,"path":1605,"stem":1606,"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":1608,"stem":1609,"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":1611,"stem":1612,"titleTemplate":6},"/docs/4.x/api/utils/on-nuxt-ready","docs/4.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":1614,"stem":1615,"titleTemplate":6},"/docs/4.x/api/utils/prefetch-components","docs/4.x/4.api/3.utils/prefetch-components",{"title":706,"path":1617,"stem":1618,"titleTemplate":6},"/docs/4.x/api/utils/preload-components","docs/4.x/4.api/3.utils/preload-components",{"title":710,"path":1620,"stem":1621,"titleTemplate":6},"/docs/4.x/api/utils/preload-route-components","docs/4.x/4.api/3.utils/preload-route-components",{"title":714,"path":1623,"stem":1624,"titleTemplate":6},"/docs/4.x/api/utils/prerender-routes","docs/4.x/4.api/3.utils/prerender-routes",{"title":718,"path":1626,"stem":1627,"titleTemplate":6},"/docs/4.x/api/utils/refresh-cookie","docs/4.x/4.api/3.utils/refresh-cookie",{"title":722,"path":1629,"stem":1630,"titleTemplate":6},"/docs/4.x/api/utils/refresh-nuxt-data","docs/4.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":1632,"stem":1633,"titleTemplate":6},"/docs/4.x/api/utils/reload-nuxt-app","docs/4.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":1635,"stem":1636,"titleTemplate":6},"/docs/4.x/api/utils/set-page-layout","docs/4.x/4.api/3.utils/set-page-layout",{"title":734,"path":1638,"stem":1639,"titleTemplate":6},"/docs/4.x/api/utils/set-response-status","docs/4.x/4.api/3.utils/set-response-status",{"title":738,"path":1641,"stem":1642,"titleTemplate":6},"/docs/4.x/api/utils/show-error","docs/4.x/4.api/3.utils/show-error",{"title":742,"path":1644,"stem":1645,"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":1647,"stem":1648,"children":1649,"page":108},"/docs/4.x/api/commands","docs/4.x/4.api/4.commands",[1650,1653,1656,1659,1662,1665,1668,1671,1674,1677,1680,1683,1686,1689,1692,1695],{"title":753,"path":1651,"stem":1652,"titleTemplate":6},"/docs/4.x/api/commands/add","docs/4.x/4.api/4.commands/add",{"title":757,"path":1654,"stem":1655,"titleTemplate":6},"/docs/4.x/api/commands/analyze","docs/4.x/4.api/4.commands/analyze",{"title":761,"path":1657,"stem":1658,"titleTemplate":6},"/docs/4.x/api/commands/build","docs/4.x/4.api/4.commands/build",{"title":765,"path":1660,"stem":1661,"titleTemplate":6},"/docs/4.x/api/commands/build-module","docs/4.x/4.api/4.commands/build-module",{"title":769,"path":1663,"stem":1664,"titleTemplate":6},"/docs/4.x/api/commands/cleanup","docs/4.x/4.api/4.commands/cleanup",{"title":773,"path":1666,"stem":1667,"titleTemplate":6},"/docs/4.x/api/commands/dev","docs/4.x/4.api/4.commands/dev",{"title":777,"path":1669,"stem":1670,"titleTemplate":6},"/docs/4.x/api/commands/devtools","docs/4.x/4.api/4.commands/devtools",{"title":781,"path":1672,"stem":1673,"titleTemplate":6},"/docs/4.x/api/commands/generate","docs/4.x/4.api/4.commands/generate",{"title":785,"path":1675,"stem":1676,"titleTemplate":6},"/docs/4.x/api/commands/info","docs/4.x/4.api/4.commands/info",{"title":789,"path":1678,"stem":1679,"titleTemplate":6},"/docs/4.x/api/commands/init","docs/4.x/4.api/4.commands/init",{"title":793,"path":1681,"stem":1682,"titleTemplate":6},"/docs/4.x/api/commands/module","docs/4.x/4.api/4.commands/module",{"title":797,"path":1684,"stem":1685,"titleTemplate":6},"/docs/4.x/api/commands/prepare","docs/4.x/4.api/4.commands/prepare",{"title":801,"path":1687,"stem":1688,"titleTemplate":6},"/docs/4.x/api/commands/preview","docs/4.x/4.api/4.commands/preview",{"title":805,"path":1690,"stem":1691,"titleTemplate":6},"/docs/4.x/api/commands/test","docs/4.x/4.api/4.commands/test",{"title":809,"path":1693,"stem":1694,"titleTemplate":6},"/docs/4.x/api/commands/typecheck","docs/4.x/4.api/4.commands/typecheck",{"title":813,"path":1696,"stem":1697,"titleTemplate":6},"/docs/4.x/api/commands/upgrade","docs/4.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":1699,"stem":1700,"children":1701,"page":108},"/docs/4.x/api/kit","docs/4.x/4.api/5.kit",[1702,1705,1708,1711,1714,1717,1720,1723,1726,1729,1732,1735,1738,1741,1744,1747,1750,1753],{"title":276,"path":1703,"stem":1704,"titleTemplate":6},"/docs/4.x/api/kit/modules","docs/4.x/4.api/5.kit/1.modules",{"title":399,"path":1706,"stem":1707,"titleTemplate":6},"/docs/4.x/api/kit/runtime-config","docs/4.x/4.api/5.kit/10.runtime-config",{"title":829,"path":1709,"stem":1710,"titleTemplate":6},"/docs/4.x/api/kit/templates","docs/4.x/4.api/5.kit/10.templates",{"title":833,"path":1712,"stem":1713,"titleTemplate":6},"/docs/4.x/api/kit/nitro","docs/4.x/4.api/5.kit/11.nitro",{"title":837,"path":1715,"stem":1716,"titleTemplate":6},"/docs/4.x/api/kit/resolving","docs/4.x/4.api/5.kit/12.resolving",{"title":841,"path":1718,"stem":1719,"titleTemplate":6},"/docs/4.x/api/kit/logging","docs/4.x/4.api/5.kit/13.logging",{"title":845,"path":1721,"stem":1722,"titleTemplate":6},"/docs/4.x/api/kit/builder","docs/4.x/4.api/5.kit/14.builder",{"title":849,"path":1724,"stem":1725,"titleTemplate":6},"/docs/4.x/api/kit/examples","docs/4.x/4.api/5.kit/15.examples",{"title":84,"path":1727,"stem":1728,"titleTemplate":6},"/docs/4.x/api/kit/layers","docs/4.x/4.api/5.kit/16.layers",{"title":856,"path":1730,"stem":1731,"titleTemplate":6},"/docs/4.x/api/kit/programmatic","docs/4.x/4.api/5.kit/2.programmatic",{"title":860,"path":1733,"stem":1734,"titleTemplate":6},"/docs/4.x/api/kit/compatibility","docs/4.x/4.api/5.kit/3.compatibility",{"title":268,"path":1736,"stem":1737,"titleTemplate":6},"/docs/4.x/api/kit/autoimports","docs/4.x/4.api/5.kit/4.autoimports",{"title":434,"path":1739,"stem":1740,"titleTemplate":6},"/docs/4.x/api/kit/components","docs/4.x/4.api/5.kit/5.components",{"title":870,"path":1742,"stem":1743,"titleTemplate":6},"/docs/4.x/api/kit/context","docs/4.x/4.api/5.kit/6.context",{"title":874,"path":1745,"stem":1746,"titleTemplate":6},"/docs/4.x/api/kit/pages","docs/4.x/4.api/5.kit/7.pages",{"title":878,"path":1748,"stem":1749,"titleTemplate":6},"/docs/4.x/api/kit/layout","docs/4.x/4.api/5.kit/8.layout",{"title":882,"path":1751,"stem":1752,"titleTemplate":6},"/docs/4.x/api/kit/head","docs/4.x/4.api/5.kit/9.head",{"title":886,"path":1754,"stem":1755,"titleTemplate":6},"/docs/4.x/api/kit/plugins","docs/4.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":1757,"stem":1758,"children":1759,"page":108},"/docs/4.x/api/advanced","docs/4.x/4.api/6.advanced",[1760,1763],{"title":407,"path":1761,"stem":1762,"titleTemplate":6},"/docs/4.x/api/advanced/hooks","docs/4.x/4.api/6.advanced/1.hooks",{"title":899,"path":1764,"stem":1765,"titleTemplate":6},"/docs/4.x/api/advanced/import-meta","docs/4.x/4.api/6.advanced/2.import-meta",{"title":903,"path":1767,"stem":1768,"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":1770,"stem":1771,"children":1772,"page":108},"/docs/4.x/examples","docs/4.x/4.examples",[1773,1776,1795,1808,1839],{"title":914,"path":1774,"stem":1775,"titleTemplate":6},"/docs/4.x/examples/hello-world","docs/4.x/4.examples/0.hello-world",{"title":395,"path":1777,"stem":1778,"children":1779,"page":108},"/docs/4.x/examples/features","docs/4.x/4.examples/1.features",[1780,1783,1786,1789,1792],{"title":922,"path":1781,"stem":1782,"titleTemplate":6},"/docs/4.x/examples/features/auto-imports","docs/4.x/4.examples/1.features/1.auto-imports",{"title":64,"path":1784,"stem":1785,"titleTemplate":6},"/docs/4.x/examples/features/data-fetching","docs/4.x/4.examples/1.features/2.data-fetching",{"title":69,"path":1787,"stem":1788,"titleTemplate":6},"/docs/4.x/examples/features/state-management","docs/4.x/4.examples/1.features/3.state-management",{"title":932,"path":1790,"stem":1791,"titleTemplate":6},"/docs/4.x/examples/features/meta-tags","docs/4.x/4.examples/1.features/4.meta-tags",{"title":936,"path":1793,"stem":1794,"titleTemplate":6},"/docs/4.x/examples/features/layouts","docs/4.x/4.examples/1.features/5.layouts",{"title":49,"path":1796,"stem":1797,"children":1798,"page":108},"/docs/4.x/examples/routing","docs/4.x/4.examples/2.routing",[1799,1802,1805],{"title":944,"path":1800,"stem":1801,"titleTemplate":6},"/docs/4.x/examples/routing/middleware","docs/4.x/4.examples/2.routing/middleware",{"title":874,"path":1803,"stem":1804,"titleTemplate":6},"/docs/4.x/examples/routing/pages","docs/4.x/4.examples/2.routing/pages",{"title":951,"path":1806,"stem":1807,"titleTemplate":6},"/docs/4.x/examples/routing/universal-router","docs/4.x/4.examples/2.routing/universal-router",{"title":890,"path":1809,"stem":1810,"children":1811,"page":108},"/docs/4.x/examples/advanced","docs/4.x/4.examples/4.advanced",[1812,1815,1818,1821,1824,1827,1830,1833,1836],{"title":84,"path":1813,"stem":1814,"titleTemplate":6},"/docs/4.x/examples/advanced/config-extends","docs/4.x/4.examples/4.advanced/config-extends",{"title":74,"path":1816,"stem":1817,"titleTemplate":6},"/docs/4.x/examples/advanced/error-handling","docs/4.x/4.examples/4.advanced/error-handling",{"title":965,"path":1819,"stem":1820,"titleTemplate":6},"/docs/4.x/examples/advanced/jsx","docs/4.x/4.examples/4.advanced/jsx",{"title":969,"path":1822,"stem":1823,"titleTemplate":6},"/docs/4.x/examples/advanced/locale","docs/4.x/4.examples/4.advanced/locale",{"title":973,"path":1825,"stem":1826,"titleTemplate":6},"/docs/4.x/examples/advanced/module-extend-pages","docs/4.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":1828,"stem":1829,"titleTemplate":6},"/docs/4.x/examples/advanced/teleport","docs/4.x/4.examples/4.advanced/teleport",{"title":99,"path":1831,"stem":1832,"titleTemplate":6},"/docs/4.x/examples/advanced/testing","docs/4.x/4.examples/4.advanced/testing",{"title":519,"path":1834,"stem":1835,"titleTemplate":6},"/docs/4.x/examples/advanced/use-cookie","docs/4.x/4.examples/4.advanced/use-cookie",{"title":987,"path":1837,"stem":1838,"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":1840,"stem":1841,"children":1842,"page":108},"/docs/4.x/examples/experimental","docs/4.x/4.examples/7.experimental",[1843],{"title":996,"path":1844,"stem":1845,"titleTemplate":6},"/docs/4.x/examples/experimental/wasm","docs/4.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1847,"stem":1848,"children":1849,"page":108},"/docs/4.x/community","docs/4.x/5.community",[1850,1853,1856,1859,1862,1865],{"title":1007,"path":1851,"stem":1852,"titleTemplate":6,"icon":1010},"/docs/4.x/community/getting-help","docs/4.x/5.community/2.getting-help",{"title":1012,"path":1854,"stem":1855,"titleTemplate":6,"icon":1015},"/docs/4.x/community/reporting-bugs","docs/4.x/5.community/3.reporting-bugs",{"title":1017,"path":1857,"stem":1858,"titleTemplate":6,"icon":1020},"/docs/4.x/community/contribution","docs/4.x/5.community/4.contribution",{"title":1022,"path":1860,"stem":1861,"titleTemplate":6,"icon":1025},"/docs/4.x/community/framework-contribution","docs/4.x/5.community/5.framework-contribution",{"title":1027,"path":1863,"stem":1864,"titleTemplate":6,"icon":1030},"/docs/4.x/community/roadmap","docs/4.x/5.community/6.roadmap",{"title":1032,"path":1866,"stem":1867,"titleTemplate":6,"icon":1035},"/docs/4.x/community/changelog","docs/4.x/5.community/7.changelog",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1869,"stem":1870,"children":1871,"page":108},"/docs/4.x/bridge","docs/4.x/6.bridge",[1872,1875,1878,1881,1884,1887,1890,1893,1896,1899],{"title":1044,"path":1873,"stem":1874,"titleTemplate":6},"/docs/4.x/bridge/overview","docs/4.x/6.bridge/1.overview",{"title":29,"path":1876,"stem":1877,"titleTemplate":6},"/docs/4.x/bridge/configuration","docs/4.x/6.bridge/10.configuration",{"title":280,"path":1879,"stem":1880,"titleTemplate":6},"/docs/4.x/bridge/typescript","docs/4.x/6.bridge/2.typescript",{"title":1054,"path":1882,"stem":1883,"titleTemplate":6},"/docs/4.x/bridge/bridge-composition-api","docs/4.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1885,"stem":1886,"titleTemplate":6},"/docs/4.x/bridge/plugins-and-middleware","docs/4.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1888,"stem":1889,"titleTemplate":6},"/docs/4.x/bridge/nuxt3-compatible-api","docs/4.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1891,"stem":1892,"titleTemplate":6},"/docs/4.x/bridge/meta","docs/4.x/6.bridge/6.meta",{"title":399,"path":1894,"stem":1895,"titleTemplate":6},"/docs/4.x/bridge/runtime-config","docs/4.x/6.bridge/7.runtime-config",{"title":833,"path":1897,"stem":1898,"titleTemplate":6},"/docs/4.x/bridge/nitro","docs/4.x/6.bridge/8.nitro",{"title":1075,"path":1900,"stem":1901,"titleTemplate":6},"/docs/4.x/bridge/vite","docs/4.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1903,"stem":1904,"children":1905,"page":108},"/docs/4.x/migration","docs/4.x/7.migration",[1906,1909,1912,1915,1918,1921,1924,1927,1930,1933,1936],{"title":1044,"path":1907,"stem":1908,"titleTemplate":6},"/docs/4.x/migration/overview","docs/4.x/7.migration/1.overview",{"title":1088,"path":1910,"stem":1911,"titleTemplate":6},"/docs/4.x/migration/bundling","docs/4.x/7.migration/10.bundling",{"title":79,"path":1913,"stem":1914,"titleTemplate":6},"/docs/4.x/migration/server","docs/4.x/7.migration/11.server",{"title":29,"path":1916,"stem":1917,"titleTemplate":6},"/docs/4.x/migration/configuration","docs/4.x/7.migration/2.configuration",{"title":276,"path":1919,"stem":1920,"titleTemplate":6},"/docs/4.x/migration/module-authors","docs/4.x/7.migration/20.module-authors",{"title":922,"path":1922,"stem":1923,"titleTemplate":6},"/docs/4.x/migration/auto-imports","docs/4.x/7.migration/3.auto-imports",{"title":932,"path":1925,"stem":1926,"titleTemplate":6},"/docs/4.x/migration/meta","docs/4.x/7.migration/4.meta",{"title":1058,"path":1928,"stem":1929,"titleTemplate":6},"/docs/4.x/migration/plugins-and-middleware","docs/4.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1931,"stem":1932,"titleTemplate":6},"/docs/4.x/migration/pages-and-layouts","docs/4.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1934,"stem":1935,"titleTemplate":6},"/docs/4.x/migration/component-options","docs/4.x/7.migration/7.component-options",{"title":399,"path":1937,"stem":1938,"titleTemplate":6},"/docs/4.x/migration/runtime-config","docs/4.x/7.migration/8.runtime-config",{"title":1940,"path":1941,"stem":1942,"children":1943,"page":108},"Blog","/blog","blog",[1944,1948,1952,1956,1960,1964,1968,1972,1976,1980,1984,1988,1992,1996,2000,2004,2008,2012,2016,2020,2024],{"title":1945,"path":1946,"stem":1947},"Announcing 3.0","/blog/v3","blog/1.v3",{"title":1949,"path":1950,"stem":1951},"Nuxt 3.3","/blog/v3-3","blog/10.v3-3",{"title":1953,"path":1954,"stem":1955},"Nuxt 3.4","/blog/v3-4","blog/11.v3-4",{"title":1957,"path":1958,"stem":1959},"Nuxt 3.5","/blog/v3-5","blog/12.v3-5",{"title":1961,"path":1962,"stem":1963},"Nuxt 3.6","/blog/v3-6","blog/13.v3-6",{"title":1965,"path":1966,"stem":1967},"Nuxt on the Edge","/blog/nuxt-on-the-edge","blog/14.nuxt-on-the-edge",{"title":1969,"path":1970,"stem":1971},"Nuxt DevTools v1.0","/blog/nuxt-devtools-v1-0","blog/18.nuxt-devtools-v1-0",{"title":1973,"path":1974,"stem":1975},"Nuxt: A vision for 2023","/blog/vision-2023","blog/2.vision-2023",{"title":1977,"path":1978,"stem":1979},"The Evolution of Shiki v1.0","/blog/shiki-v1","blog/21.shiki-v1",{"title":1981,"path":1982,"stem":1983},"Refreshed Nuxt ESLint Integrations","/blog/eslint-module","blog/24.eslint-module",{"title":1985,"path":1986,"stem":1987},"Introducing Nuxt Scripts","/blog/nuxt-scripts","blog/26.nuxt-scripts",{"title":1989,"path":1990,"stem":1991},"Introducing Nuxt Icon v1","/blog/nuxt-icon-v1-0","blog/29.nuxt-icon-v1-0",{"title":1993,"path":1994,"stem":1995},"Introducing Nuxt DevTools","/blog/introducing-nuxt-devtools","blog/3.introducing-nuxt-devtools",{"title":1997,"path":1998,"stem":1999},"Announcing Nuxt 3 Release Candidate","/blog/nuxt3-rc","blog/3.nuxt3-rc",{"title":2001,"path":2002,"stem":2003},"Nuxt 2 End-of-Life (EOL)","/blog/nuxt2-eol","blog/4.nuxt2-eol",{"title":2005,"path":2006,"stem":2007},"Introducing Nuxt 3 Beta","/blog/nuxt3-beta","blog/4.nuxt3-beta",{"title":2009,"path":2010,"stem":2011},"Going Full Static","/blog/going-full-static","blog/5.going-full-static",{"title":2013,"path":2014,"stem":2015},"Introducing Smart Prefetching","/blog/introducing-smart-prefetching","blog/6.introducing-smart-prefetching",{"title":2017,"path":2018,"stem":2019},"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":2021,"path":2022,"stem":2023},"Nuxt 2 Static Improvements","/blog/nuxt-static-improvements","blog/8.nuxt-static-improvements",{"title":2025,"path":2026,"stem":2027},"Nuxt 2: From Terminal to Browser","/blog/nuxtjs-from-terminal-to-browser","blog/9.nuxtjs-from-terminal-to-browser",{"v3":2029,"v4":2030,"v2":2031},"3.21.1","4.3.1","2.18.1",{"id":2033,"title":132,"body":2034,"description":5548,"extension":5549,"links":6,"meta":5550,"navigation":5553,"path":133,"seo":5554,"stem":134,"titleTemplate":6,"__hash__":5555},"docsv3/docs/3.x/2.directory-structure/1.components.md",{"type":2035,"value":2036,"toc":5527},"minimark",[2037,2041,2088,2168,2173,2176,2218,2221,2235,2249,2260,2362,2376,2380,2425,2428,2579,2588,2593,2596,2636,2647,2656,2660,2667,2673,2861,2865,2868,2871,2874,2879,2882,2891,2903,2909,2912,2961,2971,2986,2991,2994,2997,3045,3056,3061,3064,3121,3135,3146,3151,3154,3211,3222,3227,3230,3287,3292,3295,3442,3446,3449,3497,3501,3508,3644,3648,3651,3715,3719,3725,3951,3955,3961,4139,4144,4148,4162,4351,4355,4369,4451,4455,4462,4483,4535,4543,4561,4569,4573,4576,4583,4587,4596,4600,4603,4606,4609,4657,4664,4686,4764,4780,4785,4790,4795,4800,4804,4813,4820,4911,4924,4928,4938,4941,4966,4971,4978,4990,4994,5003,5033,5083,5087,5095,5097,5101,5104,5117,5120,5204,5214,5376,5383,5426,5435,5514,5520,5523],[2038,2039,2040],"p",{},"Nuxt automatically imports any components in this directory (along with components that are registered by any modules you may be using).",[2042,2043,2048],"pre",{"className":2044,"code":2045,"filename":110,"language":2046,"meta":2047,"style":2047},"language-bash shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","-| components/\n---| AppHeader.vue\n---| AppFooter.vue\n","bash","",[2049,2050,2051,2067,2078],"code",{"__ignoreMap":2047},[2052,2053,2056,2060,2064],"span",{"class":2054,"line":2055},"line",1,[2052,2057,2059],{"class":2058},"s52Pk","-",[2052,2061,2063],{"class":2062},"sDfIl","|",[2052,2065,2066],{"class":2058}," components/\n",[2052,2068,2070,2073,2075],{"class":2054,"line":2069},2,[2052,2071,2072],{"class":2058},"---",[2052,2074,2063],{"class":2062},[2052,2076,2077],{"class":2058}," AppHeader.vue\n",[2052,2079,2081,2083,2085],{"class":2054,"line":2080},3,[2052,2082,2072],{"class":2058},[2052,2084,2063],{"class":2062},[2052,2086,2087],{"class":2058}," AppFooter.vue\n",[2042,2089,2093],{"className":2090,"code":2091,"filename":219,"language":2092,"meta":2047,"style":2047},"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",[2049,2094,2095,2107,2117,2128,2138,2148,2158],{"__ignoreMap":2047},[2052,2096,2097,2100,2104],{"class":2054,"line":2055},[2052,2098,2099],{"class":2062},"\u003C",[2052,2101,2103],{"class":2102},"sRlkE","template",[2052,2105,2106],{"class":2062},">\n",[2052,2108,2109,2112,2115],{"class":2054,"line":2069},[2052,2110,2111],{"class":2062},"  \u003C",[2052,2113,2114],{"class":2102},"div",[2052,2116,2106],{"class":2062},[2052,2118,2119,2122,2125],{"class":2054,"line":2080},[2052,2120,2121],{"class":2062},"    \u003C",[2052,2123,2124],{"class":2102},"AppHeader",[2052,2126,2127],{"class":2062}," />\n",[2052,2129,2131,2133,2136],{"class":2054,"line":2130},4,[2052,2132,2121],{"class":2062},[2052,2134,2135],{"class":2102},"NuxtPage",[2052,2137,2127],{"class":2062},[2052,2139,2141,2143,2146],{"class":2054,"line":2140},5,[2052,2142,2121],{"class":2062},[2052,2144,2145],{"class":2102},"AppFooter",[2052,2147,2127],{"class":2062},[2052,2149,2151,2154,2156],{"class":2054,"line":2150},6,[2052,2152,2153],{"class":2062},"  \u003C/",[2052,2155,2114],{"class":2102},[2052,2157,2106],{"class":2062},[2052,2159,2161,2164,2166],{"class":2054,"line":2160},7,[2052,2162,2163],{"class":2062},"\u003C/",[2052,2165,2103],{"class":2102},[2052,2167,2106],{"class":2062},[2169,2170,2172],"h2",{"id":2171},"component-names","Component Names",[2038,2174,2175],{},"If you have a component in nested directories such as:",[2042,2177,2179],{"className":2044,"code":2178,"filename":110,"language":2046,"meta":2047,"style":2047},"-| components/\n---| base/\n-----| foo/\n-------| Button.vue\n",[2049,2180,2181,2189,2198,2208],{"__ignoreMap":2047},[2052,2182,2183,2185,2187],{"class":2054,"line":2055},[2052,2184,2059],{"class":2058},[2052,2186,2063],{"class":2062},[2052,2188,2066],{"class":2058},[2052,2190,2191,2193,2195],{"class":2054,"line":2069},[2052,2192,2072],{"class":2058},[2052,2194,2063],{"class":2062},[2052,2196,2197],{"class":2058}," base/\n",[2052,2199,2200,2203,2205],{"class":2054,"line":2080},[2052,2201,2202],{"class":2058},"-----",[2052,2204,2063],{"class":2062},[2052,2206,2207],{"class":2058}," foo/\n",[2052,2209,2210,2213,2215],{"class":2054,"line":2130},[2052,2211,2212],{"class":2058},"-------",[2052,2214,2063],{"class":2062},[2052,2216,2217],{"class":2058}," Button.vue\n",[2038,2219,2220],{},"... 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:",[2042,2222,2224],{"className":2090,"code":2223,"language":2092,"meta":2047,"style":2047},"\u003CBaseFooButton />\n",[2049,2225,2226],{"__ignoreMap":2047},[2052,2227,2228,2230,2233],{"class":2054,"line":2055},[2052,2229,2099],{"class":2062},[2052,2231,2232],{"class":2102},"BaseFooButton",[2052,2234,2127],{"class":2062},[2236,2237,2238],"note",{},[2038,2239,2240,2241,2244,2245,2248],{},"For clarity, we recommend that the component's filename matches its name. So, in the example above, you could rename ",[2049,2242,2243],{},"Button.vue"," to be ",[2049,2246,2247],{},"BaseFooButton.vue",".",[2038,2250,2251,2252,2255,2256,2259],{},"If you want to auto-import components based only on its name, not path, then you need to set ",[2049,2253,2254],{},"pathPrefix"," option to ",[2049,2257,2258],{},"false"," using extended form of the configuration object:",[2042,2261,2266],{"className":2262,"code":2263,"filename":233,"language":2264,"meta":2265,"style":2047},"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",[2049,2267,2268,2288,2299,2304,2324,2341,2346,2353],{"__ignoreMap":2047},[2052,2269,2270,2274,2277,2281,2285],{"class":2054,"line":2055},[2052,2271,2273],{"class":2272},"s8R28","export",[2052,2275,2276],{"class":2272}," default",[2052,2278,2280],{"class":2279},"s3cPz"," defineNuxtConfig",[2052,2282,2284],{"class":2283},"sZSNi","(",[2052,2286,2287],{"class":2062},"{\n",[2052,2289,2290,2293,2296],{"class":2054,"line":2069},[2052,2291,2292],{"class":2102},"  components",[2052,2294,2295],{"class":2062},":",[2052,2297,2298],{"class":2283}," [\n",[2052,2300,2301],{"class":2054,"line":2080},[2052,2302,2303],{"class":2062},"    {\n",[2052,2305,2306,2309,2311,2314,2318,2321],{"class":2054,"line":2130},[2052,2307,2308],{"class":2102},"      path",[2052,2310,2295],{"class":2062},[2052,2312,2313],{"class":2062}," '",[2052,2315,2317],{"class":2316},"sGFVr","~/components",[2052,2319,2320],{"class":2062},"'",[2052,2322,2323],{"class":2062},",\n",[2052,2325,2329,2332,2334,2338],{"class":2326,"line":2140},[2054,2327,2328],"diff","add",[2052,2330,2331],{"class":2102},"      pathPrefix",[2052,2333,2295],{"class":2062},[2052,2335,2337],{"class":2336},"sbKd-"," false",[2052,2339,2340],{"class":2062},",",[2052,2342,2343],{"class":2054,"line":2150},[2052,2344,2345],{"class":2062},"    },\n",[2052,2347,2348,2351],{"class":2054,"line":2160},[2052,2349,2350],{"class":2283},"  ]",[2052,2352,2323],{"class":2062},[2052,2354,2356,2359],{"class":2054,"line":2355},8,[2052,2357,2358],{"class":2062},"}",[2052,2360,2361],{"class":2283},")\n",[2038,2363,2364,2365,2368,2369,2372,2373,2248],{},"This registers the components using the same strategy as used in Nuxt 2. For example, ",[2049,2366,2367],{},"~/components/Some/MyComponent.vue"," will be usable as ",[2049,2370,2371],{},"\u003CMyComponent>"," and not ",[2049,2374,2375],{},"\u003CSomeMyComponent>",[2169,2377,2379],{"id":2378},"dynamic-components","Dynamic Components",[2038,2381,2382,2383,2413,2414,2417,2418,2421,2422,2424],{},"If you want to use the Vue ",[2049,2384,2387,2389,2392,2395,2399,2402,2405,2408,2410],{"className":2385,"language":2386,"style":2047},"language-vue shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","vue",[2052,2388,2099],{"class":2062},[2052,2390,2391],{"class":2102},"component",[2052,2393,2394],{"class":2062}," :",[2052,2396,2398],{"class":2397},"smZ93","is",[2052,2400,2401],{"class":2062},"=",[2052,2403,2404],{"class":2062},"\"",[2052,2406,2407],{"class":2283},"someComputedComponent",[2052,2409,2404],{"class":2062},[2052,2411,2412],{"class":2062},">"," syntax, you need to use the ",[2049,2415,2416],{},"resolveComponent"," helper provided by Vue or import the component directly from ",[2049,2419,2420],{},"#components"," and pass it into ",[2049,2423,2398],{}," prop.",[2038,2426,2427],{},"For example:",[2042,2429,2432],{"className":2385,"code":2430,"filename":2431,"language":2386,"meta":2047,"style":2047},"\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",[2049,2433,2434,2457,2481,2486,2510,2518,2522,2530,2550,2570],{"__ignoreMap":2047},[2052,2435,2436,2438,2441,2444,2447,2449,2451,2453,2455],{"class":2054,"line":2055},[2052,2437,2099],{"class":2062},[2052,2439,2440],{"class":2102},"script",[2052,2442,2443],{"class":2397}," setup",[2052,2445,2446],{"class":2397}," lang",[2052,2448,2401],{"class":2062},[2052,2450,2404],{"class":2062},[2052,2452,2264],{"class":2316},[2052,2454,2404],{"class":2062},[2052,2456,2106],{"class":2062},[2052,2458,2459,2462,2465,2468,2471,2474,2476,2478],{"class":2054,"line":2069},[2052,2460,2461],{"class":2272},"import",[2052,2463,2464],{"class":2062}," {",[2052,2466,2467],{"class":2283}," SomeComponent",[2052,2469,2470],{"class":2062}," }",[2052,2472,2473],{"class":2272}," from",[2052,2475,2313],{"class":2062},[2052,2477,2420],{"class":2316},[2052,2479,2480],{"class":2062},"'\n",[2052,2482,2483],{"class":2054,"line":2080},[2052,2484,2485],{"emptyLinePlaceholder":1196},"\n",[2052,2487,2488,2491,2494,2496,2499,2501,2503,2506,2508],{"class":2054,"line":2130},[2052,2489,2490],{"class":2397},"const",[2052,2492,2493],{"class":2283}," MyButton ",[2052,2495,2401],{"class":2062},[2052,2497,2498],{"class":2279}," resolveComponent",[2052,2500,2284],{"class":2283},[2052,2502,2320],{"class":2062},[2052,2504,2505],{"class":2316},"MyButton",[2052,2507,2320],{"class":2062},[2052,2509,2361],{"class":2283},[2052,2511,2512,2514,2516],{"class":2054,"line":2140},[2052,2513,2163],{"class":2062},[2052,2515,2440],{"class":2102},[2052,2517,2106],{"class":2062},[2052,2519,2520],{"class":2054,"line":2150},[2052,2521,2485],{"emptyLinePlaceholder":1196},[2052,2523,2524,2526,2528],{"class":2054,"line":2160},[2052,2525,2099],{"class":2062},[2052,2527,2103],{"class":2102},[2052,2529,2106],{"class":2062},[2052,2531,2532,2534,2536,2539,2541,2543,2546,2548],{"class":2054,"line":2355},[2052,2533,2111],{"class":2062},[2052,2535,2391],{"class":2102},[2052,2537,2538],{"class":2397}," :is",[2052,2540,2401],{"class":2062},[2052,2542,2404],{"class":2062},[2052,2544,2545],{"class":2316},"clickable ? MyButton : 'div'",[2052,2547,2404],{"class":2062},[2052,2549,2127],{"class":2062},[2052,2551,2553,2555,2557,2559,2561,2563,2566,2568],{"class":2054,"line":2552},9,[2052,2554,2111],{"class":2062},[2052,2556,2391],{"class":2102},[2052,2558,2538],{"class":2397},[2052,2560,2401],{"class":2062},[2052,2562,2404],{"class":2062},[2052,2564,2565],{"class":2316},"SomeComponent",[2052,2567,2404],{"class":2062},[2052,2569,2127],{"class":2062},[2052,2571,2573,2575,2577],{"class":2054,"line":2572},10,[2052,2574,2163],{"class":2062},[2052,2576,2103],{"class":2102},[2052,2578,2106],{"class":2062},[2580,2581,2582],"important",{},[2038,2583,2584,2585,2587],{},"If you are using ",[2049,2586,2416],{}," 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.",[2589,2590],"video-accordion",{"title":2591,"video-id":2592},"Watch Daniel Roe's short video about resolveComponent()","4kq8E5IUM2U",[2038,2594,2595],{},"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.",[2042,2597,2600],{"className":2598,"code":2599,"language":2327,"meta":2047,"style":2047},"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",[2049,2601,2602,2607,2612,2620,2627,2631],{"__ignoreMap":2047},[2052,2603,2604],{"class":2054,"line":2055},[2052,2605,2606],{"class":2283},"  export default defineNuxtConfig({\n",[2052,2608,2609],{"class":2054,"line":2069},[2052,2610,2611],{"class":2283},"    components: {\n",[2052,2613,2614,2617],{"class":2054,"line":2080},[2052,2615,2616],{"class":2062},"+",[2052,2618,2619],{"class":2316},"     global: true,\n",[2052,2621,2622,2624],{"class":2054,"line":2130},[2052,2623,2616],{"class":2062},[2052,2625,2626],{"class":2316},"     dirs: ['~/components']\n",[2052,2628,2629],{"class":2054,"line":2140},[2052,2630,2345],{"class":2283},[2052,2632,2633],{"class":2054,"line":2150},[2052,2634,2635],{"class":2283},"  })\n",[2038,2637,2638,2639,2642,2643,2646],{},"You can also selectively register some components globally by placing them in a ",[2049,2640,2641],{},"~/components/global"," directory, or by using a ",[2049,2644,2645],{},".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.",[2236,2648,2649],{},[2038,2650,2651,2652,2655],{},"The ",[2049,2653,2654],{},"global"," option can also be set per component directory.",[2169,2657,2659],{"id":2658},"dynamic-imports","Dynamic Imports",[2038,2661,2662,2663,2666],{},"To dynamically import a component (also known as lazy-loading a component) all you need to do is add the ",[2049,2664,2665],{},"Lazy"," prefix to the component's name. This is particularly useful if the component is not always needed.",[2038,2668,2669,2670,2672],{},"By using the ",[2049,2671,2665],{}," prefix you can delay loading the component code until the right moment, which can be helpful for optimizing your JavaScript bundle size.",[2042,2674,2676],{"className":2385,"code":2675,"filename":2431,"language":2386,"meta":2047,"style":2047},"\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",[2049,2677,2678,2698,2716,2724,2728,2736,2744,2762,2783,2790,2805,2820,2826,2832,2843,2852],{"__ignoreMap":2047},[2052,2679,2680,2682,2684,2686,2688,2690,2692,2694,2696],{"class":2054,"line":2055},[2052,2681,2099],{"class":2062},[2052,2683,2440],{"class":2102},[2052,2685,2443],{"class":2397},[2052,2687,2446],{"class":2397},[2052,2689,2401],{"class":2062},[2052,2691,2404],{"class":2062},[2052,2693,2264],{"class":2316},[2052,2695,2404],{"class":2062},[2052,2697,2106],{"class":2062},[2052,2699,2700,2702,2705,2707,2710,2712,2714],{"class":2054,"line":2069},[2052,2701,2490],{"class":2397},[2052,2703,2704],{"class":2283}," show ",[2052,2706,2401],{"class":2062},[2052,2708,2709],{"class":2279}," ref",[2052,2711,2284],{"class":2283},[2052,2713,2258],{"class":2336},[2052,2715,2361],{"class":2283},[2052,2717,2718,2720,2722],{"class":2054,"line":2080},[2052,2719,2163],{"class":2062},[2052,2721,2440],{"class":2102},[2052,2723,2106],{"class":2062},[2052,2725,2726],{"class":2054,"line":2130},[2052,2727,2485],{"emptyLinePlaceholder":1196},[2052,2729,2730,2732,2734],{"class":2054,"line":2140},[2052,2731,2099],{"class":2062},[2052,2733,2103],{"class":2102},[2052,2735,2106],{"class":2062},[2052,2737,2738,2740,2742],{"class":2054,"line":2150},[2052,2739,2111],{"class":2062},[2052,2741,2114],{"class":2102},[2052,2743,2106],{"class":2062},[2052,2745,2746,2748,2751,2753,2756,2758,2760],{"class":2054,"line":2160},[2052,2747,2121],{"class":2062},[2052,2749,2750],{"class":2102},"h1",[2052,2752,2412],{"class":2062},[2052,2754,2755],{"class":2283},"Mountains",[2052,2757,2163],{"class":2062},[2052,2759,2750],{"class":2102},[2052,2761,2106],{"class":2062},[2052,2763,2764,2766,2769,2772,2774,2776,2779,2781],{"class":2054,"line":2355},[2052,2765,2121],{"class":2062},[2052,2767,2768],{"class":2102},"LazyMountainsList",[2052,2770,2771],{"class":2397}," v-if",[2052,2773,2401],{"class":2062},[2052,2775,2404],{"class":2062},[2052,2777,2778],{"class":2316},"show",[2052,2780,2404],{"class":2062},[2052,2782,2127],{"class":2062},[2052,2784,2785,2787],{"class":2054,"line":2552},[2052,2786,2121],{"class":2062},[2052,2788,2789],{"class":2102},"button\n",[2052,2791,2792,2795,2797,2799,2802],{"class":2054,"line":2572},[2052,2793,2794],{"class":2397},"      v-if",[2052,2796,2401],{"class":2062},[2052,2798,2404],{"class":2062},[2052,2800,2801],{"class":2316},"!show",[2052,2803,2804],{"class":2062},"\"\n",[2052,2806,2808,2811,2813,2815,2818],{"class":2054,"line":2807},11,[2052,2809,2810],{"class":2397},"      @click",[2052,2812,2401],{"class":2062},[2052,2814,2404],{"class":2062},[2052,2816,2817],{"class":2316},"show = true",[2052,2819,2804],{"class":2062},[2052,2821,2823],{"class":2054,"line":2822},12,[2052,2824,2825],{"class":2062},"    >\n",[2052,2827,2829],{"class":2054,"line":2828},13,[2052,2830,2831],{"class":2283},"      Show List\n",[2052,2833,2835,2838,2841],{"class":2054,"line":2834},14,[2052,2836,2837],{"class":2062},"    \u003C/",[2052,2839,2840],{"class":2102},"button",[2052,2842,2106],{"class":2062},[2052,2844,2846,2848,2850],{"class":2054,"line":2845},15,[2052,2847,2153],{"class":2062},[2052,2849,2114],{"class":2102},[2052,2851,2106],{"class":2062},[2052,2853,2855,2857,2859],{"class":2054,"line":2854},16,[2052,2856,2163],{"class":2062},[2052,2858,2103],{"class":2102},[2052,2860,2106],{"class":2062},[2169,2862,2864],{"id":2863},"delayed-or-lazy-hydration","Delayed (or Lazy) Hydration",[2038,2866,2867],{},"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.",[2038,2869,2870],{},"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.",[2038,2872,2873],{},"Nuxt supports this using lazy (or delayed) hydration, allowing you to control when components become interactive.",[2875,2876,2878],"h3",{"id":2877},"hydration-strategies","Hydration Strategies",[2038,2880,2881],{},"Nuxt provides a range of built-in hydration strategies. Only one strategy can be used per lazy component.",[2236,2883,2884],{},[2038,2885,2886,2887,2890],{},"Any prop change on a lazily hydrated component will trigger hydration immediately. (e.g., changing a prop on a component with ",[2049,2888,2889],{},"hydrate-never"," will cause it to hydrate)",[2892,2893,2894],"warning",{},[2038,2895,2896,2897,2900,2901,2248],{},"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 ",[2049,2898,2899],{},"v-bind","). It also does not work with direct imports from ",[2049,2902,2420],{},[2904,2905,2907],"h4",{"id":2906},"hydrate-on-visible",[2049,2908,2906],{},[2038,2910,2911],{},"Hydrates the component when it becomes visible in the viewport.",[2042,2913,2915],{"className":2385,"code":2914,"filename":2431,"language":2386,"meta":2047,"style":2047},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-visible />\n  \u003C/div>\n\u003C/template>\n",[2049,2916,2917,2925,2933,2945,2953],{"__ignoreMap":2047},[2052,2918,2919,2921,2923],{"class":2054,"line":2055},[2052,2920,2099],{"class":2062},[2052,2922,2103],{"class":2102},[2052,2924,2106],{"class":2062},[2052,2926,2927,2929,2931],{"class":2054,"line":2069},[2052,2928,2111],{"class":2062},[2052,2930,2114],{"class":2102},[2052,2932,2106],{"class":2062},[2052,2934,2935,2937,2940,2943],{"class":2054,"line":2080},[2052,2936,2121],{"class":2062},[2052,2938,2939],{"class":2102},"LazyMyComponent",[2052,2941,2942],{"class":2397}," hydrate-on-visible",[2052,2944,2127],{"class":2062},[2052,2946,2947,2949,2951],{"class":2054,"line":2130},[2052,2948,2153],{"class":2062},[2052,2950,2114],{"class":2102},[2052,2952,2106],{"class":2062},[2052,2954,2955,2957,2959],{"class":2054,"line":2140},[2052,2956,2163],{"class":2062},[2052,2958,2103],{"class":2102},[2052,2960,2106],{"class":2062},[2962,2963,2966],"read-more",{"to":2964,"title":2965},"https://developer.mozilla.org/en-US/docs/Web/API/IntersectionObserver/IntersectionObserver","IntersectionObserver options",[2038,2967,2968,2969,2248],{},"Read more about the options for ",[2049,2970,2906],{},[2236,2972,2973],{},[2038,2974,2975,2976,2248],{},"Under the hood, this uses Vue's built-in ",[2977,2978,2982,2985],"a",{"href":2979,"rel":2980},"https://vuejs.org/guide/components/async#hydrate-on-visible",[2981],"nofollow",[2049,2983,2984],{},"hydrateOnVisible"," strategy",[2904,2987,2989],{"id":2988},"hydrate-on-idle",[2049,2990,2988],{},[2038,2992,2993],{},"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.",[2038,2995,2996],{},"You can also pass a number which serves as a max timeout.",[2042,2998,3000],{"className":2385,"code":2999,"filename":2431,"language":2386,"meta":2047,"style":2047},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-idle />\n  \u003C/div>\n\u003C/template>\n",[2049,3001,3002,3010,3018,3029,3037],{"__ignoreMap":2047},[2052,3003,3004,3006,3008],{"class":2054,"line":2055},[2052,3005,2099],{"class":2062},[2052,3007,2103],{"class":2102},[2052,3009,2106],{"class":2062},[2052,3011,3012,3014,3016],{"class":2054,"line":2069},[2052,3013,2111],{"class":2062},[2052,3015,2114],{"class":2102},[2052,3017,2106],{"class":2062},[2052,3019,3020,3022,3024,3027],{"class":2054,"line":2080},[2052,3021,2121],{"class":2062},[2052,3023,2939],{"class":2102},[2052,3025,3026],{"class":2397}," hydrate-on-idle",[2052,3028,2127],{"class":2062},[2052,3030,3031,3033,3035],{"class":2054,"line":2130},[2052,3032,2153],{"class":2062},[2052,3034,2114],{"class":2102},[2052,3036,2106],{"class":2062},[2052,3038,3039,3041,3043],{"class":2054,"line":2140},[2052,3040,2163],{"class":2062},[2052,3042,2103],{"class":2102},[2052,3044,2106],{"class":2062},[2236,3046,3047],{},[2038,3048,2975,3049,2248],{},[2977,3050,3053,2985],{"href":3051,"rel":3052},"https://vuejs.org/guide/components/async#hydrate-on-idle",[2981],[2049,3054,3055],{},"hydrateOnIdle",[2904,3057,3059],{"id":3058},"hydrate-on-interaction",[2049,3060,3058],{},[2038,3062,3063],{},"Hydrates the component after a specified interaction (e.g., click, mouseover).",[2042,3065,3067],{"className":2385,"code":3066,"filename":2431,"language":2386,"meta":2047,"style":2047},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-interaction=\"mouseover\" />\n  \u003C/div>\n\u003C/template>\n",[2049,3068,3069,3077,3085,3105,3113],{"__ignoreMap":2047},[2052,3070,3071,3073,3075],{"class":2054,"line":2055},[2052,3072,2099],{"class":2062},[2052,3074,2103],{"class":2102},[2052,3076,2106],{"class":2062},[2052,3078,3079,3081,3083],{"class":2054,"line":2069},[2052,3080,2111],{"class":2062},[2052,3082,2114],{"class":2102},[2052,3084,2106],{"class":2062},[2052,3086,3087,3089,3091,3094,3096,3098,3101,3103],{"class":2054,"line":2080},[2052,3088,2121],{"class":2062},[2052,3090,2939],{"class":2102},[2052,3092,3093],{"class":2397}," hydrate-on-interaction",[2052,3095,2401],{"class":2062},[2052,3097,2404],{"class":2062},[2052,3099,3100],{"class":2316},"mouseover",[2052,3102,2404],{"class":2062},[2052,3104,2127],{"class":2062},[2052,3106,3107,3109,3111],{"class":2054,"line":2130},[2052,3108,2153],{"class":2062},[2052,3110,2114],{"class":2102},[2052,3112,2106],{"class":2062},[2052,3114,3115,3117,3119],{"class":2054,"line":2140},[2052,3116,2163],{"class":2062},[2052,3118,2103],{"class":2102},[2052,3120,2106],{"class":2062},[2038,3122,3123,3124,3127,3128,3131,3132,2248],{},"If you do not pass an event or list of events, it defaults to hydrating on ",[2049,3125,3126],{},"pointerenter",", ",[2049,3129,3130],{},"click"," and ",[2049,3133,3134],{},"focus",[2236,3136,3137],{},[2038,3138,2975,3139,2248],{},[2977,3140,3143,2985],{"href":3141,"rel":3142},"https://vuejs.org/guide/components/async#hydrate-on-interaction",[2981],[2049,3144,3145],{},"hydrateOnInteraction",[2904,3147,3149],{"id":3148},"hydrate-on-media-query",[2049,3150,3148],{},[2038,3152,3153],{},"Hydrates the component when the window matches a media query.",[2042,3155,3157],{"className":2385,"code":3156,"filename":2431,"language":2386,"meta":2047,"style":2047},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-on-media-query=\"(max-width: 768px)\" />\n  \u003C/div>\n\u003C/template>\n",[2049,3158,3159,3167,3175,3195,3203],{"__ignoreMap":2047},[2052,3160,3161,3163,3165],{"class":2054,"line":2055},[2052,3162,2099],{"class":2062},[2052,3164,2103],{"class":2102},[2052,3166,2106],{"class":2062},[2052,3168,3169,3171,3173],{"class":2054,"line":2069},[2052,3170,2111],{"class":2062},[2052,3172,2114],{"class":2102},[2052,3174,2106],{"class":2062},[2052,3176,3177,3179,3181,3184,3186,3188,3191,3193],{"class":2054,"line":2080},[2052,3178,2121],{"class":2062},[2052,3180,2939],{"class":2102},[2052,3182,3183],{"class":2397}," hydrate-on-media-query",[2052,3185,2401],{"class":2062},[2052,3187,2404],{"class":2062},[2052,3189,3190],{"class":2316},"(max-width: 768px)",[2052,3192,2404],{"class":2062},[2052,3194,2127],{"class":2062},[2052,3196,3197,3199,3201],{"class":2054,"line":2130},[2052,3198,2153],{"class":2062},[2052,3200,2114],{"class":2102},[2052,3202,2106],{"class":2062},[2052,3204,3205,3207,3209],{"class":2054,"line":2140},[2052,3206,2163],{"class":2062},[2052,3208,2103],{"class":2102},[2052,3210,2106],{"class":2062},[2236,3212,3213],{},[2038,3214,2975,3215,2248],{},[2977,3216,3219,2985],{"href":3217,"rel":3218},"https://vuejs.org/guide/components/async#hydrate-on-media-query",[2981],[2049,3220,3221],{},"hydrateOnMediaQuery",[2904,3223,3225],{"id":3224},"hydrate-after",[2049,3226,3224],{},[2038,3228,3229],{},"Hydrates the component after a specified delay (in milliseconds).",[2042,3231,3233],{"className":2385,"code":3232,"filename":2431,"language":2386,"meta":2047,"style":2047},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent :hydrate-after=\"2000\" />\n  \u003C/div>\n\u003C/template>\n",[2049,3234,3235,3243,3251,3271,3279],{"__ignoreMap":2047},[2052,3236,3237,3239,3241],{"class":2054,"line":2055},[2052,3238,2099],{"class":2062},[2052,3240,2103],{"class":2102},[2052,3242,2106],{"class":2062},[2052,3244,3245,3247,3249],{"class":2054,"line":2069},[2052,3246,2111],{"class":2062},[2052,3248,2114],{"class":2102},[2052,3250,2106],{"class":2062},[2052,3252,3253,3255,3257,3260,3262,3264,3267,3269],{"class":2054,"line":2080},[2052,3254,2121],{"class":2062},[2052,3256,2939],{"class":2102},[2052,3258,3259],{"class":2397}," :hydrate-after",[2052,3261,2401],{"class":2062},[2052,3263,2404],{"class":2062},[2052,3265,3266],{"class":2316},"2000",[2052,3268,2404],{"class":2062},[2052,3270,2127],{"class":2062},[2052,3272,3273,3275,3277],{"class":2054,"line":2130},[2052,3274,2153],{"class":2062},[2052,3276,2114],{"class":2102},[2052,3278,2106],{"class":2062},[2052,3280,3281,3283,3285],{"class":2054,"line":2140},[2052,3282,2163],{"class":2062},[2052,3284,2103],{"class":2102},[2052,3286,2106],{"class":2062},[2904,3288,3290],{"id":3289},"hydrate-when",[2049,3291,3289],{},[2038,3293,3294],{},"Hydrates the component based on a boolean condition.",[2042,3296,3298],{"className":2385,"code":3297,"filename":2431,"language":2386,"meta":2047,"style":2047},"\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",[2049,3299,3300,3308,3316,3336,3344,3352,3356,3376,3393,3407,3413,3429,3434],{"__ignoreMap":2047},[2052,3301,3302,3304,3306],{"class":2054,"line":2055},[2052,3303,2099],{"class":2062},[2052,3305,2103],{"class":2102},[2052,3307,2106],{"class":2062},[2052,3309,3310,3312,3314],{"class":2054,"line":2069},[2052,3311,2111],{"class":2062},[2052,3313,2114],{"class":2102},[2052,3315,2106],{"class":2062},[2052,3317,3318,3320,3322,3325,3327,3329,3332,3334],{"class":2054,"line":2080},[2052,3319,2121],{"class":2062},[2052,3321,2939],{"class":2102},[2052,3323,3324],{"class":2397}," :hydrate-when",[2052,3326,2401],{"class":2062},[2052,3328,2404],{"class":2062},[2052,3330,3331],{"class":2316},"isReady",[2052,3333,2404],{"class":2062},[2052,3335,2127],{"class":2062},[2052,3337,3338,3340,3342],{"class":2054,"line":2130},[2052,3339,2153],{"class":2062},[2052,3341,2114],{"class":2102},[2052,3343,2106],{"class":2062},[2052,3345,3346,3348,3350],{"class":2054,"line":2140},[2052,3347,2163],{"class":2062},[2052,3349,2103],{"class":2102},[2052,3351,2106],{"class":2062},[2052,3353,3354],{"class":2054,"line":2150},[2052,3355,2485],{"emptyLinePlaceholder":1196},[2052,3357,3358,3360,3362,3364,3366,3368,3370,3372,3374],{"class":2054,"line":2160},[2052,3359,2099],{"class":2062},[2052,3361,2440],{"class":2102},[2052,3363,2443],{"class":2397},[2052,3365,2446],{"class":2397},[2052,3367,2401],{"class":2062},[2052,3369,2404],{"class":2062},[2052,3371,2264],{"class":2316},[2052,3373,2404],{"class":2062},[2052,3375,2106],{"class":2062},[2052,3377,3378,3380,3383,3385,3387,3389,3391],{"class":2054,"line":2355},[2052,3379,2490],{"class":2397},[2052,3381,3382],{"class":2283}," isReady ",[2052,3384,2401],{"class":2062},[2052,3386,2709],{"class":2279},[2052,3388,2284],{"class":2283},[2052,3390,2258],{"class":2336},[2052,3392,2361],{"class":2283},[2052,3394,3395,3398,3401,3404],{"class":2054,"line":2552},[2052,3396,3397],{"class":2397},"function",[2052,3399,3400],{"class":2279}," myFunction",[2052,3402,3403],{"class":2062}," ()",[2052,3405,3406],{"class":2062}," {\n",[2052,3408,3409],{"class":2054,"line":2572},[2052,3410,3412],{"class":3411},"sWuyu","  // trigger custom hydration strategy...\n",[2052,3414,3415,3418,3420,3423,3426],{"class":2054,"line":2807},[2052,3416,3417],{"class":2283},"  isReady",[2052,3419,2248],{"class":2062},[2052,3421,3422],{"class":2283},"value",[2052,3424,3425],{"class":2062}," =",[2052,3427,3428],{"class":2336}," true\n",[2052,3430,3431],{"class":2054,"line":2822},[2052,3432,3433],{"class":2062},"}\n",[2052,3435,3436,3438,3440],{"class":2054,"line":2828},[2052,3437,2163],{"class":2062},[2052,3439,2440],{"class":2102},[2052,3441,2106],{"class":2062},[2904,3443,3444],{"id":2889},[2049,3445,2889],{},[2038,3447,3448],{},"Never hydrates the component.",[2042,3450,3452],{"className":2385,"code":3451,"filename":2431,"language":2386,"meta":2047,"style":2047},"\u003Ctemplate>\n  \u003Cdiv>\n    \u003CLazyMyComponent hydrate-never />\n  \u003C/div>\n\u003C/template>\n",[2049,3453,3454,3462,3470,3481,3489],{"__ignoreMap":2047},[2052,3455,3456,3458,3460],{"class":2054,"line":2055},[2052,3457,2099],{"class":2062},[2052,3459,2103],{"class":2102},[2052,3461,2106],{"class":2062},[2052,3463,3464,3466,3468],{"class":2054,"line":2069},[2052,3465,2111],{"class":2062},[2052,3467,2114],{"class":2102},[2052,3469,2106],{"class":2062},[2052,3471,3472,3474,3476,3479],{"class":2054,"line":2080},[2052,3473,2121],{"class":2062},[2052,3475,2939],{"class":2102},[2052,3477,3478],{"class":2397}," hydrate-never",[2052,3480,2127],{"class":2062},[2052,3482,3483,3485,3487],{"class":2054,"line":2130},[2052,3484,2153],{"class":2062},[2052,3486,2114],{"class":2102},[2052,3488,2106],{"class":2062},[2052,3490,3491,3493,3495],{"class":2054,"line":2140},[2052,3492,2163],{"class":2062},[2052,3494,2103],{"class":2102},[2052,3496,2106],{"class":2062},[2875,3498,3500],{"id":3499},"listening-to-hydration-events","Listening to Hydration Events",[2038,3502,3503,3504,3507],{},"All delayed hydration components emit a ",[2049,3505,3506],{},"@hydrated"," event when they are hydrated.",[2042,3509,3511],{"className":2385,"code":3510,"filename":2431,"language":2386,"meta":2047,"style":2047},"\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",[2049,3512,3513,3521,3529,3536,3541,3555,3560,3568,3576,3580,3600,3611,3632,3636],{"__ignoreMap":2047},[2052,3514,3515,3517,3519],{"class":2054,"line":2055},[2052,3516,2099],{"class":2062},[2052,3518,2103],{"class":2102},[2052,3520,2106],{"class":2062},[2052,3522,3523,3525,3527],{"class":2054,"line":2069},[2052,3524,2111],{"class":2062},[2052,3526,2114],{"class":2102},[2052,3528,2106],{"class":2062},[2052,3530,3531,3533],{"class":2054,"line":2080},[2052,3532,2121],{"class":2062},[2052,3534,3535],{"class":2102},"LazyMyComponent\n",[2052,3537,3538],{"class":2054,"line":2130},[2052,3539,3540],{"class":2397},"      hydrate-on-visible\n",[2052,3542,3543,3546,3548,3550,3553],{"class":2054,"line":2140},[2052,3544,3545],{"class":2397},"      @hydrated",[2052,3547,2401],{"class":2062},[2052,3549,2404],{"class":2062},[2052,3551,3552],{"class":2316},"onHydrate",[2052,3554,2804],{"class":2062},[2052,3556,3557],{"class":2054,"line":2150},[2052,3558,3559],{"class":2062},"    />\n",[2052,3561,3562,3564,3566],{"class":2054,"line":2160},[2052,3563,2153],{"class":2062},[2052,3565,2114],{"class":2102},[2052,3567,2106],{"class":2062},[2052,3569,3570,3572,3574],{"class":2054,"line":2355},[2052,3571,2163],{"class":2062},[2052,3573,2103],{"class":2102},[2052,3575,2106],{"class":2062},[2052,3577,3578],{"class":2054,"line":2552},[2052,3579,2485],{"emptyLinePlaceholder":1196},[2052,3581,3582,3584,3586,3588,3590,3592,3594,3596,3598],{"class":2054,"line":2572},[2052,3583,2099],{"class":2062},[2052,3585,2440],{"class":2102},[2052,3587,2443],{"class":2397},[2052,3589,2446],{"class":2397},[2052,3591,2401],{"class":2062},[2052,3593,2404],{"class":2062},[2052,3595,2264],{"class":2316},[2052,3597,2404],{"class":2062},[2052,3599,2106],{"class":2062},[2052,3601,3602,3604,3607,3609],{"class":2054,"line":2807},[2052,3603,3397],{"class":2397},[2052,3605,3606],{"class":2279}," onHydrate",[2052,3608,3403],{"class":2062},[2052,3610,3406],{"class":2062},[2052,3612,3613,3616,3618,3621,3623,3625,3628,3630],{"class":2054,"line":2822},[2052,3614,3615],{"class":2283},"  console",[2052,3617,2248],{"class":2062},[2052,3619,3620],{"class":2279},"log",[2052,3622,2284],{"class":2102},[2052,3624,2320],{"class":2062},[2052,3626,3627],{"class":2316},"Component has been hydrated!",[2052,3629,2320],{"class":2062},[2052,3631,2361],{"class":2102},[2052,3633,3634],{"class":2054,"line":2828},[2052,3635,3433],{"class":2062},[2052,3637,3638,3640,3642],{"class":2054,"line":2834},[2052,3639,2163],{"class":2062},[2052,3641,2440],{"class":2102},[2052,3643,2106],{"class":2062},[2875,3645,3647],{"id":3646},"caveats-and-best-practices","Caveats and Best Practices",[2038,3649,3650],{},"Delayed hydration can offer performance benefits, but it's essential to use it correctly:",[3652,3653,3654,3662,3672,3682,3706],"ol",{},[3655,3656,3657,3661],"li",{},[3658,3659,3660],"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.",[3655,3663,3664,3667,3668,3671],{},[3658,3665,3666],{},"Conditional Rendering:"," When using ",[2049,3669,3670],{},"v-if=\"false\""," on a lazy component, you might not need delayed hydration. You can just use a normal lazy component.",[3655,3673,3674,3677,3678,3681],{},[3658,3675,3676],{},"Shared State:"," Be mindful of shared state (",[2049,3679,3680],{},"v-model",") across multiple components. Updating the model in one component can trigger hydration in all components bound to that model.",[3655,3683,3684,3687,3688],{},[3658,3685,3686],{},"Use Each Strategy's Intended Use Case:"," Each strategy is optimized for a specific purpose.",[3689,3690,3691,3696,3701],"ul",{},[3655,3692,3693,3695],{},[2049,3694,3289],{}," is best for components that might not always need to be hydrated.",[3655,3697,3698,3700],{},[2049,3699,3224],{}," is for components that can wait a specific amount of time.",[3655,3702,3703,3705],{},[2049,3704,2988],{}," is for components that can be hydrated when the browser is idle.",[3655,3707,3708,3714],{},[3658,3709,3710,3711,3713],{},"Avoid ",[2049,3712,2889],{}," on interactive components:"," If a component requires user interaction, it should not be set to never hydrate.",[2169,3716,3718],{"id":3717},"direct-imports","Direct Imports",[2038,3720,3721,3722,3724],{},"You can also explicitly import components from ",[2049,3723,2420],{}," if you want or need to bypass Nuxt's auto-importing functionality.",[2042,3726,3728],{"className":2385,"code":3727,"filename":2431,"language":2386,"meta":2047,"style":2047},"\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",[2049,3729,3730,3750,3774,3778,3794,3802,3806,3814,3822,3838,3856,3862,3874,3886,3890,3894,3902,3933,3942],{"__ignoreMap":2047},[2052,3731,3732,3734,3736,3738,3740,3742,3744,3746,3748],{"class":2054,"line":2055},[2052,3733,2099],{"class":2062},[2052,3735,2440],{"class":2102},[2052,3737,2443],{"class":2397},[2052,3739,2446],{"class":2397},[2052,3741,2401],{"class":2062},[2052,3743,2404],{"class":2062},[2052,3745,2264],{"class":2316},[2052,3747,2404],{"class":2062},[2052,3749,2106],{"class":2062},[2052,3751,3752,3754,3756,3759,3761,3764,3766,3768,3770,3772],{"class":2054,"line":2069},[2052,3753,2461],{"class":2272},[2052,3755,2464],{"class":2062},[2052,3757,3758],{"class":2283}," LazyMountainsList",[2052,3760,2340],{"class":2062},[2052,3762,3763],{"class":2283}," NuxtLink",[2052,3765,2470],{"class":2062},[2052,3767,2473],{"class":2272},[2052,3769,2313],{"class":2062},[2052,3771,2420],{"class":2316},[2052,3773,2480],{"class":2062},[2052,3775,3776],{"class":2054,"line":2080},[2052,3777,2485],{"emptyLinePlaceholder":1196},[2052,3779,3780,3782,3784,3786,3788,3790,3792],{"class":2054,"line":2130},[2052,3781,2490],{"class":2397},[2052,3783,2704],{"class":2283},[2052,3785,2401],{"class":2062},[2052,3787,2709],{"class":2279},[2052,3789,2284],{"class":2283},[2052,3791,2258],{"class":2336},[2052,3793,2361],{"class":2283},[2052,3795,3796,3798,3800],{"class":2054,"line":2140},[2052,3797,2163],{"class":2062},[2052,3799,2440],{"class":2102},[2052,3801,2106],{"class":2062},[2052,3803,3804],{"class":2054,"line":2150},[2052,3805,2485],{"emptyLinePlaceholder":1196},[2052,3807,3808,3810,3812],{"class":2054,"line":2160},[2052,3809,2099],{"class":2062},[2052,3811,2103],{"class":2102},[2052,3813,2106],{"class":2062},[2052,3815,3816,3818,3820],{"class":2054,"line":2355},[2052,3817,2111],{"class":2062},[2052,3819,2114],{"class":2102},[2052,3821,2106],{"class":2062},[2052,3823,3824,3826,3828,3830,3832,3834,3836],{"class":2054,"line":2552},[2052,3825,2121],{"class":2062},[2052,3827,2750],{"class":2102},[2052,3829,2412],{"class":2062},[2052,3831,2755],{"class":2283},[2052,3833,2163],{"class":2062},[2052,3835,2750],{"class":2102},[2052,3837,2106],{"class":2062},[2052,3839,3840,3842,3844,3846,3848,3850,3852,3854],{"class":2054,"line":2572},[2052,3841,2121],{"class":2062},[2052,3843,2768],{"class":2102},[2052,3845,2771],{"class":2397},[2052,3847,2401],{"class":2062},[2052,3849,2404],{"class":2062},[2052,3851,2778],{"class":2316},[2052,3853,2404],{"class":2062},[2052,3855,2127],{"class":2062},[2052,3857,3858,3860],{"class":2054,"line":2807},[2052,3859,2121],{"class":2062},[2052,3861,2789],{"class":2102},[2052,3863,3864,3866,3868,3870,3872],{"class":2054,"line":2822},[2052,3865,2794],{"class":2397},[2052,3867,2401],{"class":2062},[2052,3869,2404],{"class":2062},[2052,3871,2801],{"class":2316},[2052,3873,2804],{"class":2062},[2052,3875,3876,3878,3880,3882,3884],{"class":2054,"line":2828},[2052,3877,2810],{"class":2397},[2052,3879,2401],{"class":2062},[2052,3881,2404],{"class":2062},[2052,3883,2817],{"class":2316},[2052,3885,2804],{"class":2062},[2052,3887,3888],{"class":2054,"line":2834},[2052,3889,2825],{"class":2062},[2052,3891,3892],{"class":2054,"line":2845},[2052,3893,2831],{"class":2283},[2052,3895,3896,3898,3900],{"class":2054,"line":2854},[2052,3897,2837],{"class":2062},[2052,3899,2840],{"class":2102},[2052,3901,2106],{"class":2062},[2052,3903,3905,3907,3910,3913,3915,3917,3920,3922,3924,3927,3929,3931],{"class":2054,"line":3904},17,[2052,3906,2121],{"class":2062},[2052,3908,3909],{"class":2102},"NuxtLink",[2052,3911,3912],{"class":2397}," to",[2052,3914,2401],{"class":2062},[2052,3916,2404],{"class":2062},[2052,3918,3919],{"class":2316},"/",[2052,3921,2404],{"class":2062},[2052,3923,2412],{"class":2062},[2052,3925,3926],{"class":2283},"Home",[2052,3928,2163],{"class":2062},[2052,3930,3909],{"class":2102},[2052,3932,2106],{"class":2062},[2052,3934,3936,3938,3940],{"class":2054,"line":3935},18,[2052,3937,2153],{"class":2062},[2052,3939,2114],{"class":2102},[2052,3941,2106],{"class":2062},[2052,3943,3945,3947,3949],{"class":2054,"line":3944},19,[2052,3946,2163],{"class":2062},[2052,3948,2103],{"class":2102},[2052,3950,2106],{"class":2062},[2169,3952,3954],{"id":3953},"custom-directories","Custom Directories",[2038,3956,3957,3958,3960],{},"By default, only the ",[2049,3959,2317],{}," 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:",[2042,3962,3965],{"className":3963,"code":3964,"filename":233,"language":2264,"meta":2265,"style":2047},"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",[2049,3966,3967,3979,3987,3992,4012,4016,4021,4047,4051,4056,4087,4091,4096,4101,4106,4111,4116,4127,4133],{"__ignoreMap":2047},[2052,3968,3969,3971,3973,3975,3977],{"class":2054,"line":2055},[2052,3970,2273],{"class":2272},[2052,3972,2276],{"class":2272},[2052,3974,2280],{"class":2279},[2052,3976,2284],{"class":2283},[2052,3978,2287],{"class":2062},[2052,3980,3981,3983,3985],{"class":2054,"line":2069},[2052,3982,2292],{"class":2102},[2052,3984,2295],{"class":2062},[2052,3986,2298],{"class":2283},[2052,3988,3989],{"class":2054,"line":2080},[2052,3990,3991],{"class":3411},"    // ~/calendar-module/components/event/Update.vue => \u003CEventUpdate />\n",[2052,3993,3994,3997,4000,4002,4004,4007,4009],{"class":2054,"line":2130},[2052,3995,3996],{"class":2062},"    {",[2052,3998,3999],{"class":2102}," path",[2052,4001,2295],{"class":2062},[2052,4003,2313],{"class":2062},[2052,4005,4006],{"class":2316},"~/calendar-module/components",[2052,4008,2320],{"class":2062},[2052,4010,4011],{"class":2062}," },\n",[2052,4013,4014],{"class":2054,"line":2140},[2052,4015,2485],{"emptyLinePlaceholder":1196},[2052,4017,4018],{"class":2054,"line":2150},[2052,4019,4020],{"class":3411},"    // ~/user-module/components/account/UserDeleteDialog.vue => \u003CUserDeleteDialog />\n",[2052,4022,4023,4025,4027,4029,4031,4034,4036,4038,4041,4043,4045],{"class":2054,"line":2160},[2052,4024,3996],{"class":2062},[2052,4026,3999],{"class":2102},[2052,4028,2295],{"class":2062},[2052,4030,2313],{"class":2062},[2052,4032,4033],{"class":2316},"~/user-module/components",[2052,4035,2320],{"class":2062},[2052,4037,2340],{"class":2062},[2052,4039,4040],{"class":2102}," pathPrefix",[2052,4042,2295],{"class":2062},[2052,4044,2337],{"class":2336},[2052,4046,4011],{"class":2062},[2052,4048,4049],{"class":2054,"line":2355},[2052,4050,2485],{"emptyLinePlaceholder":1196},[2052,4052,4053],{"class":2054,"line":2552},[2052,4054,4055],{"class":3411},"    // ~/components/special-components/Btn.vue => \u003CSpecialBtn />\n",[2052,4057,4058,4060,4062,4064,4066,4069,4071,4073,4076,4078,4080,4083,4085],{"class":2054,"line":2572},[2052,4059,3996],{"class":2062},[2052,4061,3999],{"class":2102},[2052,4063,2295],{"class":2062},[2052,4065,2313],{"class":2062},[2052,4067,4068],{"class":2316},"~/components/special-components",[2052,4070,2320],{"class":2062},[2052,4072,2340],{"class":2062},[2052,4074,4075],{"class":2102}," prefix",[2052,4077,2295],{"class":2062},[2052,4079,2313],{"class":2062},[2052,4081,4082],{"class":2316},"Special",[2052,4084,2320],{"class":2062},[2052,4086,4011],{"class":2062},[2052,4088,4089],{"class":2054,"line":2807},[2052,4090,2485],{"emptyLinePlaceholder":1196},[2052,4092,4093],{"class":2054,"line":2822},[2052,4094,4095],{"class":3411},"    // It's important that this comes last if you have overrides you wish to apply\n",[2052,4097,4098],{"class":2054,"line":2828},[2052,4099,4100],{"class":3411},"    // to sub-directories of `~/components`.\n",[2052,4102,4103],{"class":2054,"line":2834},[2052,4104,4105],{"class":3411},"    //\n",[2052,4107,4108],{"class":2054,"line":2845},[2052,4109,4110],{"class":3411},"    // ~/components/Btn.vue => \u003CBtn />\n",[2052,4112,4113],{"class":2054,"line":2854},[2052,4114,4115],{"class":3411},"    // ~/components/base/Btn.vue => \u003CBaseBtn />\n",[2052,4117,4118,4121,4123,4125],{"class":2054,"line":3904},[2052,4119,4120],{"class":2062},"    '",[2052,4122,2317],{"class":2316},[2052,4124,2320],{"class":2062},[2052,4126,2323],{"class":2062},[2052,4128,4129,4131],{"class":2054,"line":3935},[2052,4130,2350],{"class":2283},[2052,4132,2323],{"class":2062},[2052,4134,4135,4137],{"class":2054,"line":3944},[2052,4136,2358],{"class":2062},[2052,4138,2361],{"class":2283},[2236,4140,4141],{},[2038,4142,4143],{},"Any nested directories need to be added first as they are scanned in order.",[2169,4145,4147],{"id":4146},"npm-packages","npm Packages",[2038,4149,4150,4151,4157,4158,4161],{},"If you want to auto-import components from an npm package, you can use ",[2977,4152,4154],{"href":4153},"/docs/3.x/api/kit/components#addcomponent",[2049,4155,4156],{},"addComponent"," in a ",[2977,4159,4160],{"href":163},"local module"," to register them.",[4163,4164,4165,4301],"code-group",{},[2042,4166,4169],{"className":3963,"code":4167,"filename":4168,"language":2264,"meta":2265,"style":2047},"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",[2049,4170,4171,4196,4200,4212,4221,4226,4235,4251,4267,4283,4290,4295],{"__ignoreMap":2047},[2052,4172,4173,4175,4177,4180,4182,4185,4187,4189,4191,4194],{"class":2054,"line":2055},[2052,4174,2461],{"class":2272},[2052,4176,2464],{"class":2062},[2052,4178,4179],{"class":2283}," addComponent",[2052,4181,2340],{"class":2062},[2052,4183,4184],{"class":2283}," defineNuxtModule",[2052,4186,2470],{"class":2062},[2052,4188,2473],{"class":2272},[2052,4190,2313],{"class":2062},[2052,4192,4193],{"class":2316},"@nuxt/kit",[2052,4195,2480],{"class":2062},[2052,4197,4198],{"class":2054,"line":2069},[2052,4199,2485],{"emptyLinePlaceholder":1196},[2052,4201,4202,4204,4206,4208,4210],{"class":2054,"line":2080},[2052,4203,2273],{"class":2272},[2052,4205,2276],{"class":2272},[2052,4207,4184],{"class":2279},[2052,4209,2284],{"class":2283},[2052,4211,2287],{"class":2062},[2052,4213,4214,4217,4219],{"class":2054,"line":2130},[2052,4215,4216],{"class":2102},"  setup",[2052,4218,3403],{"class":2062},[2052,4220,3406],{"class":2062},[2052,4222,4223],{"class":2054,"line":2140},[2052,4224,4225],{"class":3411},"    // import { MyComponent as MyAutoImportedComponent } from 'my-npm-package'\n",[2052,4227,4228,4231,4233],{"class":2054,"line":2150},[2052,4229,4230],{"class":2279},"    addComponent",[2052,4232,2284],{"class":2102},[2052,4234,2287],{"class":2062},[2052,4236,4237,4240,4242,4244,4247,4249],{"class":2054,"line":2160},[2052,4238,4239],{"class":2102},"      name",[2052,4241,2295],{"class":2062},[2052,4243,2313],{"class":2062},[2052,4245,4246],{"class":2316},"MyAutoImportedComponent",[2052,4248,2320],{"class":2062},[2052,4250,2323],{"class":2062},[2052,4252,4253,4256,4258,4260,4263,4265],{"class":2054,"line":2355},[2052,4254,4255],{"class":2102},"      export",[2052,4257,2295],{"class":2062},[2052,4259,2313],{"class":2062},[2052,4261,4262],{"class":2316},"MyComponent",[2052,4264,2320],{"class":2062},[2052,4266,2323],{"class":2062},[2052,4268,4269,4272,4274,4276,4279,4281],{"class":2054,"line":2552},[2052,4270,4271],{"class":2102},"      filePath",[2052,4273,2295],{"class":2062},[2052,4275,2313],{"class":2062},[2052,4277,4278],{"class":2316},"my-npm-package",[2052,4280,2320],{"class":2062},[2052,4282,2323],{"class":2062},[2052,4284,4285,4288],{"class":2054,"line":2572},[2052,4286,4287],{"class":2062},"    }",[2052,4289,2361],{"class":2102},[2052,4291,4292],{"class":2054,"line":2807},[2052,4293,4294],{"class":2062},"  },\n",[2052,4296,4297,4299],{"class":2054,"line":2822},[2052,4298,2358],{"class":2062},[2052,4300,2361],{"class":2283},[2042,4302,4304],{"className":2385,"code":4303,"filename":219,"language":2386,"meta":2047,"style":2047},"\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",[2049,4305,4306,4314,4322,4327,4335,4343],{"__ignoreMap":2047},[2052,4307,4308,4310,4312],{"class":2054,"line":2055},[2052,4309,2099],{"class":2062},[2052,4311,2103],{"class":2102},[2052,4313,2106],{"class":2062},[2052,4315,4316,4318,4320],{"class":2054,"line":2069},[2052,4317,2111],{"class":2062},[2052,4319,2114],{"class":2102},[2052,4321,2106],{"class":2062},[2052,4323,4324],{"class":2054,"line":2080},[2052,4325,4326],{"class":3411},"    \u003C!--  the component uses the name we specified and is auto-imported  -->\n",[2052,4328,4329,4331,4333],{"class":2054,"line":2130},[2052,4330,2121],{"class":2062},[2052,4332,4246],{"class":2102},[2052,4334,2127],{"class":2062},[2052,4336,4337,4339,4341],{"class":2054,"line":2140},[2052,4338,2153],{"class":2062},[2052,4340,2114],{"class":2102},[2052,4342,2106],{"class":2062},[2052,4344,4345,4347,4349],{"class":2054,"line":2150},[2052,4346,2163],{"class":2062},[2052,4348,2103],{"class":2102},[2052,4350,2106],{"class":2062},[2169,4352,4354],{"id":4353},"component-extensions","Component Extensions",[2038,4356,4357,4358,4364,4365,4368],{},"By default, any file with an extension specified in the ",[2977,4359,4361,4362],{"href":4360},"/docs/3.x/api/nuxt-config#extensions","extensions key of ",[2049,4363,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 ",[2049,4366,4367],{},"extensions"," key:",[2042,4370,4372],{"className":2262,"code":4371,"filename":233,"language":2264,"meta":2265,"style":2047},"export default defineNuxtConfig({\n  components: [\n    {\n      path: '~/components',\n      extensions: ['.vue'], // [!code ++]\n    },\n  ],\n})\n",[2049,4373,4374,4386,4394,4398,4412,4435,4439,4445],{"__ignoreMap":2047},[2052,4375,4376,4378,4380,4382,4384],{"class":2054,"line":2055},[2052,4377,2273],{"class":2272},[2052,4379,2276],{"class":2272},[2052,4381,2280],{"class":2279},[2052,4383,2284],{"class":2283},[2052,4385,2287],{"class":2062},[2052,4387,4388,4390,4392],{"class":2054,"line":2069},[2052,4389,2292],{"class":2102},[2052,4391,2295],{"class":2062},[2052,4393,2298],{"class":2283},[2052,4395,4396],{"class":2054,"line":2080},[2052,4397,2303],{"class":2062},[2052,4399,4400,4402,4404,4406,4408,4410],{"class":2054,"line":2130},[2052,4401,2308],{"class":2102},[2052,4403,2295],{"class":2062},[2052,4405,2313],{"class":2062},[2052,4407,2317],{"class":2316},[2052,4409,2320],{"class":2062},[2052,4411,2323],{"class":2062},[2052,4413,4415,4418,4420,4423,4425,4428,4430,4433],{"class":4414,"line":2140},[2054,2327,2328],[2052,4416,4417],{"class":2102},"      extensions",[2052,4419,2295],{"class":2062},[2052,4421,4422],{"class":2283}," [",[2052,4424,2320],{"class":2062},[2052,4426,4427],{"class":2316},".vue",[2052,4429,2320],{"class":2062},[2052,4431,4432],{"class":2283},"]",[2052,4434,2340],{"class":2062},[2052,4436,4437],{"class":2054,"line":2150},[2052,4438,2345],{"class":2062},[2052,4440,4441,4443],{"class":2054,"line":2160},[2052,4442,2350],{"class":2283},[2052,4444,2323],{"class":2062},[2052,4446,4447,4449],{"class":2054,"line":2355},[2052,4448,2358],{"class":2062},[2052,4450,2361],{"class":2283},[2169,4452,4454],{"id":4453},"client-components","Client Components",[2038,4456,4457,4458,4461],{},"If a component is meant to be rendered only client-side, you can add the ",[2049,4459,4460],{},".client"," suffix to your component.",[2042,4463,4465],{"className":2044,"code":4464,"filename":110,"language":2046,"meta":2047,"style":2047},"| components/\n--| Comments.client.vue\n",[2049,4466,4467,4473],{"__ignoreMap":2047},[2052,4468,4469,4471],{"class":2054,"line":2055},[2052,4470,2063],{"class":2062},[2052,4472,2066],{"class":2058},[2052,4474,4475,4478,4480],{"class":2054,"line":2069},[2052,4476,4477],{"class":2058},"--",[2052,4479,2063],{"class":2062},[2052,4481,4482],{"class":2058}," Comments.client.vue\n",[2042,4484,4487],{"className":2385,"code":4485,"filename":4486,"language":2386,"meta":2047,"style":2047},"\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",[2049,4488,4489,4497,4505,4510,4519,4527],{"__ignoreMap":2047},[2052,4490,4491,4493,4495],{"class":2054,"line":2055},[2052,4492,2099],{"class":2062},[2052,4494,2103],{"class":2102},[2052,4496,2106],{"class":2062},[2052,4498,4499,4501,4503],{"class":2054,"line":2069},[2052,4500,2111],{"class":2062},[2052,4502,2114],{"class":2102},[2052,4504,2106],{"class":2062},[2052,4506,4507],{"class":2054,"line":2080},[2052,4508,4509],{"class":3411},"    \u003C!-- this component will only be rendered on client side -->\n",[2052,4511,4512,4514,4517],{"class":2054,"line":2130},[2052,4513,2121],{"class":2062},[2052,4515,4516],{"class":2102},"Comments",[2052,4518,2127],{"class":2062},[2052,4520,4521,4523,4525],{"class":2054,"line":2140},[2052,4522,2153],{"class":2062},[2052,4524,2114],{"class":2102},[2052,4526,2106],{"class":2062},[2052,4528,4529,4531,4533],{"class":2054,"line":2150},[2052,4530,2163],{"class":2062},[2052,4532,2103],{"class":2102},[2052,4534,2106],{"class":2062},[2236,4536,4537],{},[2038,4538,4539,4540,4542],{},"This feature only works with Nuxt auto-imports and ",[2049,4541,2420],{}," imports. Explicitly importing these components from their real paths does not convert them into client-only components.",[2580,4544,4545],{},[2038,4546,4547,4549,4550,4553,4554,4557,4558,4560],{},[2049,4548,4460],{}," components are rendered only after being mounted. To access the rendered template using ",[2049,4551,4552],{},"onMounted()",", add ",[2049,4555,4556],{},"await nextTick()"," in the callback of the ",[2049,4559,4552],{}," hook.",[2962,4562,4563],{"to":441},[2038,4564,4565,4566,4568],{},"You can also achieve a similar result with the ",[2049,4567,440],{}," component.",[2169,4570,4572],{"id":4571},"server-components","Server Components",[2038,4574,4575],{},"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.",[2038,4577,4578,4579,2248],{},"Server components can either be used on their own or paired with a ",[2977,4580,4582],{"href":4581},"/docs/3.x/directory-structure/components#paired-with-a-client-component","client component",[2589,4584],{"title":4585,"video-id":4586},"Watch Learn Vue video about Nuxt Server Components","u1yyXe86xJM",[4588,4589,4593],"tip",{"icon":4590,"target":4591,"to":4592},"i-lucide-newspaper","_blank","https://roe.dev/blog/nuxt-server-components",[2038,4594,4595],{},"Read Daniel Roe's guide to Nuxt Server Components.",[2875,4597,4599],{"id":4598},"standalone-server-components","Standalone server components",[2038,4601,4602],{},"Standalone server components will always be rendered on the server, also known as Islands components.",[2038,4604,4605],{},"When their props update, this will result in a network request that will update the rendered HTML in-place.",[2038,4607,4608],{},"Server components are currently experimental and in order to use them, you need to enable the 'component islands' feature in your nuxt.config:",[2042,4610,4612],{"className":3963,"code":4611,"filename":233,"language":2264,"meta":2265,"style":2047},"export default defineNuxtConfig({\n  experimental: {\n    componentIslands: true,\n  },\n})\n",[2049,4613,4614,4626,4635,4647,4651],{"__ignoreMap":2047},[2052,4615,4616,4618,4620,4622,4624],{"class":2054,"line":2055},[2052,4617,2273],{"class":2272},[2052,4619,2276],{"class":2272},[2052,4621,2280],{"class":2279},[2052,4623,2284],{"class":2283},[2052,4625,2287],{"class":2062},[2052,4627,4628,4631,4633],{"class":2054,"line":2069},[2052,4629,4630],{"class":2102},"  experimental",[2052,4632,2295],{"class":2062},[2052,4634,3406],{"class":2062},[2052,4636,4637,4640,4642,4645],{"class":2054,"line":2080},[2052,4638,4639],{"class":2102},"    componentIslands",[2052,4641,2295],{"class":2062},[2052,4643,4644],{"class":2336}," true",[2052,4646,2323],{"class":2062},[2052,4648,4649],{"class":2054,"line":2130},[2052,4650,4294],{"class":2062},[2052,4652,4653,4655],{"class":2054,"line":2140},[2052,4654,2358],{"class":2062},[2052,4656,2361],{"class":2283},[2038,4658,4659,4660,4663],{},"Now you can register server-only components with the ",[2049,4661,4662],{},".server"," suffix and use them anywhere in your application automatically.",[2042,4665,4667],{"className":2044,"code":4666,"filename":110,"language":2046,"meta":2047,"style":2047},"-| components/\n---| HighlightedMarkdown.server.vue\n",[2049,4668,4669,4677],{"__ignoreMap":2047},[2052,4670,4671,4673,4675],{"class":2054,"line":2055},[2052,4672,2059],{"class":2058},[2052,4674,2063],{"class":2062},[2052,4676,2066],{"class":2058},[2052,4678,4679,4681,4683],{"class":2054,"line":2069},[2052,4680,2072],{"class":2058},[2052,4682,2063],{"class":2062},[2052,4684,4685],{"class":2058}," HighlightedMarkdown.server.vue\n",[2042,4687,4689],{"className":2385,"code":4688,"filename":4486,"language":2386,"meta":2047,"style":2047},"\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",[2049,4690,4691,4699,4707,4712,4717,4722,4727,4748,4756],{"__ignoreMap":2047},[2052,4692,4693,4695,4697],{"class":2054,"line":2055},[2052,4694,2099],{"class":2062},[2052,4696,2103],{"class":2102},[2052,4698,2106],{"class":2062},[2052,4700,4701,4703,4705],{"class":2054,"line":2069},[2052,4702,2111],{"class":2062},[2052,4704,2114],{"class":2102},[2052,4706,2106],{"class":2062},[2052,4708,4709],{"class":2054,"line":2080},[2052,4710,4711],{"class":3411},"    \u003C!--\n",[2052,4713,4714],{"class":2054,"line":2130},[2052,4715,4716],{"class":3411},"      this will automatically be rendered on the server, meaning your markdown parsing + highlighting\n",[2052,4718,4719],{"class":2054,"line":2140},[2052,4720,4721],{"class":3411},"      libraries are not included in your client bundle.\n",[2052,4723,4724],{"class":2054,"line":2150},[2052,4725,4726],{"class":3411},"     -->\n",[2052,4728,4729,4731,4734,4737,4739,4741,4744,4746],{"class":2054,"line":2160},[2052,4730,2121],{"class":2062},[2052,4732,4733],{"class":2102},"HighlightedMarkdown",[2052,4735,4736],{"class":2397}," markdown",[2052,4738,2401],{"class":2062},[2052,4740,2404],{"class":2062},[2052,4742,4743],{"class":2316},"# Headline",[2052,4745,2404],{"class":2062},[2052,4747,2127],{"class":2062},[2052,4749,4750,4752,4754],{"class":2054,"line":2355},[2052,4751,2153],{"class":2062},[2052,4753,2114],{"class":2102},[2052,4755,2106],{"class":2062},[2052,4757,4758,4760,4762],{"class":2054,"line":2552},[2052,4759,2163],{"class":2062},[2052,4761,2103],{"class":2102},[2052,4763,2106],{"class":2062},[2038,4765,4766,4767,4771,4772,4775,4776,4779],{},"Server-only components use ",[2977,4768,4769],{"href":493},[2049,4770,492],{}," under the hood, meaning that ",[2049,4773,4774],{},"lazy"," prop and ",[2049,4777,4778],{},"#fallback"," slot are both passed down to it.",[2892,4781,4782],{},[2038,4783,4784],{},"Server components (and islands) must have a single root element. (HTML comments are considered elements as well.)",[2892,4786,4787],{},[2038,4788,4789],{},"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.",[2892,4791,4792],{},[2038,4793,4794],{},"Be careful when nesting islands within other islands as each island adds some extra overhead.",[2892,4796,4797],{},[2038,4798,4799],{},"Most features for server-only components and island components, such as slots and client components, are only available for single file components.",[2904,4801,4803],{"id":4802},"client-components-within-server-components","Client components within server components",[2236,4805,4806],{},[2038,4807,4808,4809,4812],{},"This feature needs ",[2049,4810,4811],{},"experimental.componentIslands.selectiveClient"," within your configuration to be true.",[2038,4814,4815,4816,4819],{},"You can partially hydrate a component by setting a ",[2049,4817,4818],{},"nuxt-client"," attribute on the component you wish to be loaded client-side.",[2042,4821,4824],{"className":2385,"code":4822,"filename":4823,"language":2386,"meta":2047,"style":2047},"\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",[2049,4825,4826,4834,4842,4860,4865,4872,4877,4891,4895,4903],{"__ignoreMap":2047},[2052,4827,4828,4830,4832],{"class":2054,"line":2055},[2052,4829,2099],{"class":2062},[2052,4831,2103],{"class":2102},[2052,4833,2106],{"class":2062},[2052,4835,4836,4838,4840],{"class":2054,"line":2069},[2052,4837,2111],{"class":2062},[2052,4839,2114],{"class":2102},[2052,4841,2106],{"class":2062},[2052,4843,4844,4846,4848,4850,4852,4854,4856,4858],{"class":2054,"line":2080},[2052,4845,2121],{"class":2062},[2052,4847,4733],{"class":2102},[2052,4849,4736],{"class":2397},[2052,4851,2401],{"class":2062},[2052,4853,2404],{"class":2062},[2052,4855,4743],{"class":2316},[2052,4857,2404],{"class":2062},[2052,4859,2127],{"class":2062},[2052,4861,4862],{"class":2054,"line":2130},[2052,4863,4864],{"class":3411},"    \u003C!-- Counter will be loaded and hydrated client-side -->\n",[2052,4866,4867,4869],{"class":2054,"line":2140},[2052,4868,2121],{"class":2062},[2052,4870,4871],{"class":2102},"Counter\n",[2052,4873,4874],{"class":2054,"line":2150},[2052,4875,4876],{"class":2397},"      nuxt-client\n",[2052,4878,4879,4882,4884,4886,4889],{"class":2054,"line":2160},[2052,4880,4881],{"class":2397},"      :count",[2052,4883,2401],{"class":2062},[2052,4885,2404],{"class":2062},[2052,4887,4888],{"class":2316},"5",[2052,4890,2804],{"class":2062},[2052,4892,4893],{"class":2054,"line":2355},[2052,4894,3559],{"class":2062},[2052,4896,4897,4899,4901],{"class":2054,"line":2552},[2052,4898,2153],{"class":2062},[2052,4900,2114],{"class":2102},[2052,4902,2106],{"class":2062},[2052,4904,4905,4907,4909],{"class":2054,"line":2572},[2052,4906,2163],{"class":2062},[2052,4908,2103],{"class":2102},[2052,4910,2106],{"class":2062},[2236,4912,4913],{},[2038,4914,4915,4916,4919,4920,4923],{},"This only works within a server component. Slots for client components are working only with ",[2049,4917,4918],{},"experimental.componentIsland.selectiveClient"," set to ",[2049,4921,4922],{},"'deep'"," and since they are rendered server-side, they are not interactive once client-side.",[2904,4925,4927],{"id":4926},"server-component-context","Server Component Context",[2038,4929,4930,4931,4933,4934,4937],{},"When rendering a server-only or island component, ",[2049,4932,492],{}," makes a fetch request which comes back with a ",[2049,4935,4936],{},"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.)",[2038,4939,4940],{},"This means:",[3689,4942,4943,4948,4951,4959],{},[3655,4944,4945,4946,2248],{},"A new Vue app will be created server-side to create the ",[2049,4947,4936],{},[3655,4949,4950],{},"A new 'island context' will be created while rendering the component.",[3655,4952,4953,4954,4958],{},"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 ",[4955,4956,4957],"em",{},"isolated"," from the rest of your app.",[3655,4960,4961,4962,4965],{},"Your plugins will run again when rendering the island, unless they have ",[2049,4963,4964],{},"env: { islands: false }"," set (which you can do in an object-syntax plugin).",[2580,4967,4968],{},[2038,4969,4970],{},"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.",[2038,4972,4973,4974,4977],{},"Within an island component, you can access its island context through ",[2049,4975,4976],{},"nuxtApp.ssrContext.islandContext",". Note that while island components are still marked as experimental, the format of this context may change.",[2236,4979,4980],{},[2038,4981,4982,4983,4986,4987],{},"Slots can be interactive and are wrapped within a ",[2049,4984,4985],{},"\u003Cdiv>"," with ",[2049,4988,4989],{},"display: contents;",[2875,4991,4993],{"id":4992},"paired-with-a-client-component","Paired with a Client component",[2038,4995,4996,4997,4999,5000,5002],{},"In this case, the ",[2049,4998,4662],{}," + ",[2049,5001,4460],{}," 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.",[2042,5004,5006],{"className":2044,"code":5005,"filename":110,"language":2046,"meta":2047,"style":2047},"-| components/\n---| Comments.client.vue\n---| Comments.server.vue\n",[2049,5007,5008,5016,5024],{"__ignoreMap":2047},[2052,5009,5010,5012,5014],{"class":2054,"line":2055},[2052,5011,2059],{"class":2058},[2052,5013,2063],{"class":2062},[2052,5015,2066],{"class":2058},[2052,5017,5018,5020,5022],{"class":2054,"line":2069},[2052,5019,2072],{"class":2058},[2052,5021,2063],{"class":2062},[2052,5023,4482],{"class":2058},[2052,5025,5026,5028,5030],{"class":2054,"line":2080},[2052,5027,2072],{"class":2058},[2052,5029,2063],{"class":2062},[2052,5031,5032],{"class":2058}," Comments.server.vue\n",[2042,5034,5036],{"className":2385,"code":5035,"filename":4486,"language":2386,"meta":2047,"style":2047},"\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",[2049,5037,5038,5046,5054,5059,5067,5075],{"__ignoreMap":2047},[2052,5039,5040,5042,5044],{"class":2054,"line":2055},[2052,5041,2099],{"class":2062},[2052,5043,2103],{"class":2102},[2052,5045,2106],{"class":2062},[2052,5047,5048,5050,5052],{"class":2054,"line":2069},[2052,5049,2111],{"class":2062},[2052,5051,2114],{"class":2102},[2052,5053,2106],{"class":2062},[2052,5055,5056],{"class":2054,"line":2080},[2052,5057,5058],{"class":3411},"    \u003C!-- this component will render Comments.server on the server then Comments.client once mounted in the browser -->\n",[2052,5060,5061,5063,5065],{"class":2054,"line":2130},[2052,5062,2121],{"class":2062},[2052,5064,4516],{"class":2102},[2052,5066,2127],{"class":2062},[2052,5068,5069,5071,5073],{"class":2054,"line":2140},[2052,5070,2153],{"class":2062},[2052,5072,2114],{"class":2102},[2052,5074,2106],{"class":2062},[2052,5076,5077,5079,5081],{"class":2054,"line":2150},[2052,5078,2163],{"class":2062},[2052,5080,2103],{"class":2102},[2052,5082,2106],{"class":2062},[2169,5084,5086],{"id":5085},"built-in-nuxt-components","Built-In Nuxt Components",[2038,5088,5089,5090,3131,5092,5094],{},"There are a number of components that Nuxt provides, including ",[2049,5091,440],{},[2049,5093,444],{},". You can read more about them in the API documentation.",[2962,5096],{"to":430},[2169,5098,5100],{"id":5099},"library-authors","Library Authors",[2038,5102,5103],{},"Making Vue component libraries with automatic tree-shaking and component registration is super easy. ✨",[2038,5105,5106,5107,5113,5114,5116],{},"You can use the ",[2977,5108,5110],{"href":5109},"/docs/3.x/api/kit/components#addcomponentsdir",[2049,5111,5112],{},"addComponentsDir"," method provided from the ",[2049,5115,4193],{}," to register your components directory in your Nuxt module.",[2038,5118,5119],{},"Imagine a directory structure like this:",[2042,5121,5123],{"className":2044,"code":5122,"filename":110,"language":2046,"meta":2047,"style":2047},"-| 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",[2049,5124,5125,5134,5143,5151,5160,5168,5177,5186,5195],{"__ignoreMap":2047},[2052,5126,5127,5129,5131],{"class":2054,"line":2055},[2052,5128,2059],{"class":2058},[2052,5130,2063],{"class":2062},[2052,5132,5133],{"class":2058}," node_modules/\n",[2052,5135,5136,5138,5140],{"class":2054,"line":2069},[2052,5137,2072],{"class":2058},[2052,5139,2063],{"class":2062},[2052,5141,5142],{"class":2058}," awesome-ui/\n",[2052,5144,5145,5147,5149],{"class":2054,"line":2080},[2052,5146,2202],{"class":2058},[2052,5148,2063],{"class":2062},[2052,5150,2066],{"class":2058},[2052,5152,5153,5155,5157],{"class":2054,"line":2130},[2052,5154,2212],{"class":2058},[2052,5156,2063],{"class":2062},[2052,5158,5159],{"class":2058}," Alert.vue\n",[2052,5161,5162,5164,5166],{"class":2054,"line":2140},[2052,5163,2212],{"class":2058},[2052,5165,2063],{"class":2062},[2052,5167,2217],{"class":2058},[2052,5169,5170,5172,5174],{"class":2054,"line":2150},[2052,5171,2202],{"class":2058},[2052,5173,2063],{"class":2062},[2052,5175,5176],{"class":2058}," nuxt.ts\n",[2052,5178,5179,5181,5183],{"class":2054,"line":2160},[2052,5180,2059],{"class":2058},[2052,5182,2063],{"class":2062},[2052,5184,5185],{"class":2058}," pages/\n",[2052,5187,5188,5190,5192],{"class":2054,"line":2355},[2052,5189,2072],{"class":2058},[2052,5191,2063],{"class":2062},[2052,5193,5194],{"class":2058}," index.vue\n",[2052,5196,5197,5199,5201],{"class":2054,"line":2552},[2052,5198,2059],{"class":2058},[2052,5200,2063],{"class":2062},[2052,5202,5203],{"class":2058}," nuxt.config.ts\n",[2038,5205,5206,5207,5210,5211,5213],{},"Then in ",[2049,5208,5209],{},"awesome-ui/nuxt.ts"," you can use the ",[2049,5212,5112],{}," hook:",[2042,5215,5217],{"className":3963,"code":5216,"language":2264,"meta":2265,"style":2047},"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",[2049,5218,5219,5247,5251,5263,5271,5299,5303,5308,5317,5344,5360,5366,5370],{"__ignoreMap":2047},[2052,5220,5221,5223,5225,5228,5230,5233,5235,5237,5239,5241,5243,5245],{"class":2054,"line":2055},[2052,5222,2461],{"class":2272},[2052,5224,2464],{"class":2062},[2052,5226,5227],{"class":2283}," addComponentsDir",[2052,5229,2340],{"class":2062},[2052,5231,5232],{"class":2283}," createResolver",[2052,5234,2340],{"class":2062},[2052,5236,4184],{"class":2283},[2052,5238,2470],{"class":2062},[2052,5240,2473],{"class":2272},[2052,5242,2313],{"class":2062},[2052,5244,4193],{"class":2316},[2052,5246,2480],{"class":2062},[2052,5248,5249],{"class":2054,"line":2069},[2052,5250,2485],{"emptyLinePlaceholder":1196},[2052,5252,5253,5255,5257,5259,5261],{"class":2054,"line":2080},[2052,5254,2273],{"class":2272},[2052,5256,2276],{"class":2272},[2052,5258,4184],{"class":2279},[2052,5260,2284],{"class":2283},[2052,5262,2287],{"class":2062},[2052,5264,5265,5267,5269],{"class":2054,"line":2130},[2052,5266,4216],{"class":2102},[2052,5268,3403],{"class":2062},[2052,5270,3406],{"class":2062},[2052,5272,5273,5276,5279,5281,5283,5285,5287,5289,5292,5294,5297],{"class":2054,"line":2140},[2052,5274,5275],{"class":2397},"    const",[2052,5277,5278],{"class":2283}," resolver",[2052,5280,3425],{"class":2062},[2052,5282,5232],{"class":2279},[2052,5284,2284],{"class":2102},[2052,5286,2461],{"class":2272},[2052,5288,2248],{"class":2062},[2052,5290,5291],{"class":2283},"meta",[2052,5293,2248],{"class":2062},[2052,5295,5296],{"class":2283},"url",[2052,5298,2361],{"class":2102},[2052,5300,5301],{"class":2054,"line":2150},[2052,5302,2485],{"emptyLinePlaceholder":1196},[2052,5304,5305],{"class":2054,"line":2160},[2052,5306,5307],{"class":3411},"    // Add ./components dir to the list\n",[2052,5309,5310,5313,5315],{"class":2054,"line":2355},[2052,5311,5312],{"class":2279},"    addComponentsDir",[2052,5314,2284],{"class":2102},[2052,5316,2287],{"class":2062},[2052,5318,5319,5321,5323,5325,5327,5330,5332,5334,5337,5339,5342],{"class":2054,"line":2552},[2052,5320,2308],{"class":2102},[2052,5322,2295],{"class":2062},[2052,5324,5278],{"class":2283},[2052,5326,2248],{"class":2062},[2052,5328,5329],{"class":2279},"resolve",[2052,5331,2284],{"class":2102},[2052,5333,2320],{"class":2062},[2052,5335,5336],{"class":2316},"./components",[2052,5338,2320],{"class":2062},[2052,5340,5341],{"class":2102},")",[2052,5343,2323],{"class":2062},[2052,5345,5346,5349,5351,5353,5356,5358],{"class":2054,"line":2572},[2052,5347,5348],{"class":2102},"      prefix",[2052,5350,2295],{"class":2062},[2052,5352,2313],{"class":2062},[2052,5354,5355],{"class":2316},"awesome",[2052,5357,2320],{"class":2062},[2052,5359,2323],{"class":2062},[2052,5361,5362,5364],{"class":2054,"line":2807},[2052,5363,4287],{"class":2062},[2052,5365,2361],{"class":2102},[2052,5367,5368],{"class":2054,"line":2822},[2052,5369,4294],{"class":2062},[2052,5371,5372,5374],{"class":2054,"line":2828},[2052,5373,2358],{"class":2062},[2052,5375,2361],{"class":2283},[2038,5377,5378,5379,5382],{},"That's it! Now in your project, you can import your UI library as a Nuxt module in your ",[2049,5380,5381],{},"nuxt.config"," file:",[2042,5384,5386],{"className":3963,"code":5385,"filename":233,"language":2264,"meta":2265,"style":2047},"export default defineNuxtConfig({\n  modules: ['awesome-ui/nuxt'],\n})\n",[2049,5387,5388,5400,5420],{"__ignoreMap":2047},[2052,5389,5390,5392,5394,5396,5398],{"class":2054,"line":2055},[2052,5391,2273],{"class":2272},[2052,5393,2276],{"class":2272},[2052,5395,2280],{"class":2279},[2052,5397,2284],{"class":2283},[2052,5399,2287],{"class":2062},[2052,5401,5402,5405,5407,5409,5411,5414,5416,5418],{"class":2054,"line":2069},[2052,5403,5404],{"class":2102},"  modules",[2052,5406,2295],{"class":2062},[2052,5408,4422],{"class":2283},[2052,5410,2320],{"class":2062},[2052,5412,5413],{"class":2316},"awesome-ui/nuxt",[2052,5415,2320],{"class":2062},[2052,5417,4432],{"class":2283},[2052,5419,2323],{"class":2062},[2052,5421,5422,5424],{"class":2054,"line":2080},[2052,5423,2358],{"class":2062},[2052,5425,2361],{"class":2283},[2038,5427,5428,5429,5432,5433,2295],{},"... and directly use the module components (prefixed with ",[2049,5430,5431],{},"awesome-",") in our ",[2049,5434,2431],{},[2042,5436,5438],{"className":2385,"code":5437,"language":2386,"meta":2047,"style":2047},"\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",[2049,5439,5440,5448,5456,5480,5498,5506],{"__ignoreMap":2047},[2052,5441,5442,5444,5446],{"class":2054,"line":2055},[2052,5443,2099],{"class":2062},[2052,5445,2103],{"class":2102},[2052,5447,2106],{"class":2062},[2052,5449,5450,5452,5454],{"class":2054,"line":2069},[2052,5451,2111],{"class":2062},[2052,5453,2114],{"class":2102},[2052,5455,2106],{"class":2062},[2052,5457,5458,5461,5463,5466,5468,5471,5473,5475,5477],{"class":2054,"line":2080},[2052,5459,5460],{"class":2283},"    My ",[2052,5462,2099],{"class":2062},[2052,5464,5465],{"class":2102},"AwesomeButton",[2052,5467,2412],{"class":2062},[2052,5469,5470],{"class":2283},"UI button",[2052,5472,2163],{"class":2062},[2052,5474,5465],{"class":2102},[2052,5476,2412],{"class":2062},[2052,5478,5479],{"class":2283},"!\n",[2052,5481,5482,5484,5487,5489,5492,5494,5496],{"class":2054,"line":2130},[2052,5483,2121],{"class":2062},[2052,5485,5486],{"class":2102},"awesome-alert",[2052,5488,2412],{"class":2062},[2052,5490,5491],{"class":2283},"Here's an alert!",[2052,5493,2163],{"class":2062},[2052,5495,5486],{"class":2102},[2052,5497,2106],{"class":2062},[2052,5499,5500,5502,5504],{"class":2054,"line":2140},[2052,5501,2153],{"class":2062},[2052,5503,2114],{"class":2102},[2052,5505,2106],{"class":2062},[2052,5507,5508,5510,5512],{"class":2054,"line":2150},[2052,5509,2163],{"class":2062},[2052,5511,2103],{"class":2102},[2052,5513,2106],{"class":2062},[2038,5515,5516,5517,2248],{},"It will automatically import the components only if used and also support HMR when updating your components in ",[2049,5518,5519],{},"node_modules/awesome-ui/components/",[5521,5522],"link-example",{"to":923},[5524,5525,5526],"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":2047,"searchDepth":2069,"depth":2069,"links":5528},[5529,5530,5531,5532,5537,5538,5539,5540,5541,5542,5546,5547],{"id":2171,"depth":2069,"text":2172},{"id":2378,"depth":2069,"text":2379},{"id":2658,"depth":2069,"text":2659},{"id":2863,"depth":2069,"text":2864,"children":5533},[5534,5535,5536],{"id":2877,"depth":2080,"text":2878},{"id":3499,"depth":2080,"text":3500},{"id":3646,"depth":2080,"text":3647},{"id":3717,"depth":2069,"text":3718},{"id":3953,"depth":2069,"text":3954},{"id":4146,"depth":2069,"text":4147},{"id":4353,"depth":2069,"text":4354},{"id":4453,"depth":2069,"text":4454},{"id":4571,"depth":2069,"text":4572,"children":5543},[5544,5545],{"id":4598,"depth":2080,"text":4599},{"id":4992,"depth":2080,"text":4993},{"id":5085,"depth":2069,"text":5086},{"id":5099,"depth":2069,"text":5100},"The components/ directory is where you put all your Vue components.","md",{"head":5551},{"title":5552},"components/",{"icon":135},{"title":132,"description":5548},"CurfJjvxwOzpaurvouKVBJYs7nljtVs5-Th6E31-Z2Q",[5557,5559],{"title":127,"path":128,"stem":129,"description":5558,"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":5560,"icon":140,"children":-1},"Use the composables/ directory to auto-import your Vue composables into your application.",1772101772060]