mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-25 23:22:02 +00:00
Compare commits
22 Commits
f8acd8b325
...
d57a94ef93
Author | SHA1 | Date | |
---|---|---|---|
|
d57a94ef93 | ||
|
9bf8465806 | ||
|
f94d3f2bc6 | ||
|
9c8cd4b74b | ||
|
23b1af766b | ||
|
0646244a30 | ||
|
df749b9b5b | ||
|
d218a835f3 | ||
|
d4e2b44f4c | ||
|
8eeaed5164 | ||
|
25a21f4d5a | ||
|
1edb8d2d7a | ||
|
2984d3f66a | ||
|
9e83d05e17 | ||
|
50255cb5c1 | ||
|
b5ec8f643a | ||
|
390f88bdf6 | ||
|
c90f321fb2 | ||
|
b99d5660e4 | ||
|
b73ff33136 | ||
|
c759cf3f35 | ||
|
d5cf708041 |
@ -21,8 +21,8 @@ Or follow the steps below to set up a new Nuxt project on your computer.
|
|||||||
<!-- markdownlint-disable-next-line MD001 -->
|
<!-- markdownlint-disable-next-line MD001 -->
|
||||||
#### Prerequisites
|
#### Prerequisites
|
||||||
|
|
||||||
- **Node.js** - [`v18.0.0`](https://nodejs.org/en) or newer
|
- **Node.js** - [`18.x`](https://nodejs.org/en) or newer (but we recommend the [active LTS release](https://github.com/nodejs/release#release-schedule))
|
||||||
- **Text editor** - We recommend [Visual Studio Code](https://code.visualstudio.com/) with the [official Vue extension](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (previously known as Volar)
|
- **Text editor** - There is no IDE requirement, but we recommend [Visual Studio Code](https://code.visualstudio.com/) with the [official Vue extension](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (previously known as Volar) or [WebStorm](https://www.jetbrains.com/webstorm/), which, along with [other JetBrains IDEs](https://www.jetbrains.com/ides/), offers great Nuxt support right out-of-the-box.
|
||||||
- **Terminal** - In order to run Nuxt commands
|
- **Terminal** - In order to run Nuxt commands
|
||||||
|
|
||||||
::note
|
::note
|
||||||
|
@ -189,7 +189,6 @@ export default createConfigForNuxt({
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
// Sort rule keys in eslint config
|
// Sort rule keys in eslint config
|
||||||
// @ts-expect-error incorrect types 🤔
|
|
||||||
{
|
{
|
||||||
files: ['**/eslint.config.mjs'],
|
files: ['**/eslint.config.mjs'],
|
||||||
name: 'local/sort-eslint-config',
|
name: 'local/sort-eslint-config',
|
||||||
|
@ -40,7 +40,7 @@
|
|||||||
"@nuxt/ui-templates": "workspace:*",
|
"@nuxt/ui-templates": "workspace:*",
|
||||||
"@nuxt/vite-builder": "workspace:*",
|
"@nuxt/vite-builder": "workspace:*",
|
||||||
"@nuxt/webpack-builder": "workspace:*",
|
"@nuxt/webpack-builder": "workspace:*",
|
||||||
"@types/node": "22.9.0",
|
"@types/node": "22.9.1",
|
||||||
"@unhead/dom": "1.11.11",
|
"@unhead/dom": "1.11.11",
|
||||||
"@unhead/shared": "1.11.11",
|
"@unhead/shared": "1.11.11",
|
||||||
"@unhead/vue": "1.11.11",
|
"@unhead/vue": "1.11.11",
|
||||||
@ -75,7 +75,7 @@
|
|||||||
"@nuxt/webpack-builder": "workspace:*",
|
"@nuxt/webpack-builder": "workspace:*",
|
||||||
"@testing-library/vue": "8.1.0",
|
"@testing-library/vue": "8.1.0",
|
||||||
"@types/eslint__js": "8.42.3",
|
"@types/eslint__js": "8.42.3",
|
||||||
"@types/node": "22.9.0",
|
"@types/node": "22.9.1",
|
||||||
"@types/semver": "7.5.8",
|
"@types/semver": "7.5.8",
|
||||||
"@unhead/schema": "1.11.11",
|
"@unhead/schema": "1.11.11",
|
||||||
"@unhead/vue": "1.11.11",
|
"@unhead/vue": "1.11.11",
|
||||||
@ -91,7 +91,7 @@
|
|||||||
"devalue": "5.1.1",
|
"devalue": "5.1.1",
|
||||||
"eslint": "9.15.0",
|
"eslint": "9.15.0",
|
||||||
"eslint-plugin-no-only-tests": "3.3.0",
|
"eslint-plugin-no-only-tests": "3.3.0",
|
||||||
"eslint-plugin-perfectionist": "3.9.1",
|
"eslint-plugin-perfectionist": "4.0.2",
|
||||||
"eslint-typegen": "0.3.2",
|
"eslint-typegen": "0.3.2",
|
||||||
"h3": "npm:h3-nightly@2.0.0-1718872656.6765a6e",
|
"h3": "npm:h3-nightly@2.0.0-1718872656.6765a6e",
|
||||||
"happy-dom": "15.11.6",
|
"happy-dom": "15.11.6",
|
||||||
|
@ -41,7 +41,6 @@ export default defineComponent({
|
|||||||
const nuxtApp = useNuxtApp()
|
const nuxtApp = useNuxtApp()
|
||||||
const pageRef = ref()
|
const pageRef = ref()
|
||||||
const forkRoute = inject(PageRouteSymbol, null)
|
const forkRoute = inject(PageRouteSymbol, null)
|
||||||
let previousPageKey: string | undefined | false
|
|
||||||
|
|
||||||
expose({ pageRef })
|
expose({ pageRef })
|
||||||
|
|
||||||
@ -97,10 +96,6 @@ export default defineComponent({
|
|||||||
}
|
}
|
||||||
|
|
||||||
const key = generateRouteKey(routeProps, props.pageKey)
|
const key = generateRouteKey(routeProps, props.pageKey)
|
||||||
if (!nuxtApp.isHydrating && !hasChildrenRoutes(forkRoute, routeProps.route, routeProps.Component) && previousPageKey === key) {
|
|
||||||
nuxtApp.callHook('page:loading:end')
|
|
||||||
}
|
|
||||||
previousPageKey = key
|
|
||||||
|
|
||||||
const hasTransition = !!(props.transition ?? routeProps.route.meta.pageTransition ?? defaultPageTransition)
|
const hasTransition = !!(props.transition ?? routeProps.route.meta.pageTransition ?? defaultPageTransition)
|
||||||
const transitionProps = hasTransition && _mergeTransitionProps([
|
const transitionProps = hasTransition && _mergeTransitionProps([
|
||||||
@ -161,10 +156,3 @@ function haveParentRoutesRendered (fork: RouteLocationNormalizedLoaded | null, n
|
|||||||
(c, i) => c.components?.default !== fork.matched[i]?.components?.default) ||
|
(c, i) => c.components?.default !== fork.matched[i]?.components?.default) ||
|
||||||
(Component && generateRouteKey({ route: newRoute, Component }) !== generateRouteKey({ route: fork, Component }))
|
(Component && generateRouteKey({ route: newRoute, Component }) !== generateRouteKey({ route: fork, Component }))
|
||||||
}
|
}
|
||||||
|
|
||||||
function hasChildrenRoutes (fork: RouteLocationNormalizedLoaded | null, newRoute: RouteLocationNormalizedLoaded, Component?: VNode) {
|
|
||||||
if (!fork) { return false }
|
|
||||||
|
|
||||||
const index = newRoute.matched.findIndex(m => m.components?.default === Component?.type)
|
|
||||||
return index < newRoute.matched.length - 1
|
|
||||||
}
|
|
||||||
|
429
pnpm-lock.yaml
429
pnpm-lock.yaml
File diff suppressed because it is too large
Load Diff
@ -625,6 +625,44 @@ describe('pages', () => {
|
|||||||
const html = await $fetch('/prerender/test')
|
const html = await $fetch('/prerender/test')
|
||||||
expect(html).toContain('should be prerendered: true')
|
expect(html).toContain('should be prerendered: true')
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should trigger page:loading:end only once', async () => {
|
||||||
|
const { page, consoleLogs } = await renderPage('/')
|
||||||
|
|
||||||
|
await page.getByText('to page load hook').click()
|
||||||
|
await page.waitForFunction(path => window.useNuxtApp?.()._route.fullPath === path, '/page-load-hook')
|
||||||
|
const loadingEndLogs = consoleLogs.filter(c => c.text.includes('page:loading:end'))
|
||||||
|
expect(loadingEndLogs.length).toBe(1)
|
||||||
|
|
||||||
|
await page.close()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should hide nuxt page load indicator after navigate back from nested page', async () => {
|
||||||
|
const LOAD_INDICATOR_SELECTOR = '.nuxt-loading-indicator'
|
||||||
|
const { page } = await renderPage('/')
|
||||||
|
await page.getByText('to page nuxt load indicator').click()
|
||||||
|
await page.waitForFunction(path => window.useNuxtApp?.()._route.fullPath === path, '/nested/xyz')
|
||||||
|
|
||||||
|
await page.waitForSelector(LOAD_INDICATOR_SELECTOR)
|
||||||
|
let isVisible = await page.isVisible(LOAD_INDICATOR_SELECTOR)
|
||||||
|
expect(isVisible).toBe(true)
|
||||||
|
|
||||||
|
await page.waitForSelector(LOAD_INDICATOR_SELECTOR, { state: 'hidden' })
|
||||||
|
isVisible = await page.isVisible(LOAD_INDICATOR_SELECTOR)
|
||||||
|
expect(isVisible).toBe(false)
|
||||||
|
|
||||||
|
await page.goBack()
|
||||||
|
|
||||||
|
await page.waitForSelector(LOAD_INDICATOR_SELECTOR)
|
||||||
|
isVisible = await page.isVisible(LOAD_INDICATOR_SELECTOR)
|
||||||
|
expect(isVisible).toBe(true)
|
||||||
|
|
||||||
|
await page.waitForSelector(LOAD_INDICATOR_SELECTOR, { state: 'hidden' })
|
||||||
|
isVisible = await page.isVisible(LOAD_INDICATOR_SELECTOR)
|
||||||
|
expect(isVisible).toBe(false)
|
||||||
|
|
||||||
|
await page.close()
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('nuxt composables', () => {
|
describe('nuxt composables', () => {
|
||||||
|
7
test/fixtures/basic/pages/index.vue
vendored
7
test/fixtures/basic/pages/index.vue
vendored
@ -3,6 +3,7 @@
|
|||||||
<Head>
|
<Head>
|
||||||
<Title>Basic fixture</Title>
|
<Title>Basic fixture</Title>
|
||||||
</Head>
|
</Head>
|
||||||
|
<NuxtLoadingIndicator :throttle="0" />
|
||||||
<h1>Hello Nuxt 3!</h1>
|
<h1>Hello Nuxt 3!</h1>
|
||||||
<div>RuntimeConfig | testConfig: {{ config.public.testConfig }}</div>
|
<div>RuntimeConfig | testConfig: {{ config.public.testConfig }}</div>
|
||||||
<div>Composable | foo: {{ foo }}</div>
|
<div>Composable | foo: {{ foo }}</div>
|
||||||
@ -94,6 +95,12 @@
|
|||||||
<NuxtLink to="/server-page">
|
<NuxtLink to="/server-page">
|
||||||
to server page
|
to server page
|
||||||
</NuxtLink>
|
</NuxtLink>
|
||||||
|
<NuxtLink to="/page-load-hook">
|
||||||
|
to page load hook
|
||||||
|
</NuxtLink>
|
||||||
|
<NuxtLink to="/nested/xyz">
|
||||||
|
to page nuxt load indicator
|
||||||
|
</NuxtLink>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
5
test/fixtures/basic/pages/page-load-hook.vue
vendored
Normal file
5
test/fixtures/basic/pages/page-load-hook.vue
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
Page for hook tests.
|
||||||
|
</div>
|
||||||
|
</template>
|
8
test/fixtures/basic/plugins/page-hook-plugin.ts
vendored
Normal file
8
test/fixtures/basic/plugins/page-hook-plugin.ts
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
export default defineNuxtPlugin((nuxtApp) => {
|
||||||
|
const route = useRoute()
|
||||||
|
nuxtApp.hook('page:loading:end', () => {
|
||||||
|
if (route.path === '/page-load-hook') {
|
||||||
|
console.log('page:loading:end')
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
Loading…
Reference in New Issue
Block a user