mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-08 12:36:01 +00:00
150 lines
3.3 KiB
Vue
150 lines
3.3 KiB
Vue
<template>
|
|
<div>
|
|
<NotDotClientComponent>
|
|
<ByeBye />
|
|
</NotDotClientComponent>
|
|
<div>
|
|
<Glob />
|
|
</div>
|
|
{{ hello }}
|
|
<div class="not-client">
|
|
Hello
|
|
</div>
|
|
<DotClientComponent>
|
|
<HelloWorld />
|
|
<Glob />
|
|
<SomeGlob />
|
|
<SomeIsland />
|
|
<NotToBeTreeShaken />
|
|
<ObjectPattern />
|
|
<ObjectPatternDeclaration />
|
|
<AutoImportedNotTreeShakenComponent />
|
|
<AutoImportedComponent />
|
|
<Halllo />
|
|
<Both />
|
|
<AreTreeshaken />
|
|
</DotClientComponent>
|
|
<ClientOnly>
|
|
<div class="should-be-treeshaken">
|
|
this should not be visible
|
|
</div>
|
|
<ClientImport />
|
|
<Treeshaken />
|
|
<ResolvedImport />
|
|
<FromArray />
|
|
<Please />
|
|
<Doo />
|
|
<What />
|
|
<Deep />
|
|
<Pattern />
|
|
<DontRemoveThisSinceItIsUsedInSetup />
|
|
</ClientOnly>
|
|
<ButShouldNotBeTreeShaken />
|
|
<Dont />
|
|
<That />
|
|
<NotToBeTreeShaken />
|
|
<AutoImportedNotTreeShakenComponent />
|
|
</div>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { Treeshaken } from 'somepath'
|
|
import HelloWorld from '../HelloWorld.vue'
|
|
import DontRemoveThisSinceItIsUsedInSetup from './ComponentWithProps.vue'
|
|
import { ClientImport, Glob } from '#components'
|
|
import { AreTreeshaken, Both } from '#imports'
|
|
|
|
const hello = 'world'
|
|
const ByeBye = defineAsyncComponent(() => import('./../some-glob.global.vue'))
|
|
|
|
const NotDotClientComponent = defineAsyncComponent(() => import('./../some.island.vue'))
|
|
const SomeIsland = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../some.island.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
const NotToBeTreeShaken = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
const { ObjectPattern } = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
const { ObjectPattern: ObjectPatternDeclaration } = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
const { ObjectPattern: Halllo, ButShouldNotBeTreeShaken } = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
const isThis = {}
|
|
|
|
const { woooooo, What = isThis } = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
if (import.meta.client) {
|
|
// eslint-disable-next-line no-console
|
|
console.log(woooooo)
|
|
}
|
|
|
|
const { Deep, assignment: { Pattern = ofComponent } } = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
const [FromArray] = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
const [Please, { Dont, Doo }, That] = defineAsyncComponent(async () => {
|
|
if (import.meta.client) {
|
|
return (await import('./../HelloWorld.vue'))
|
|
}
|
|
|
|
return {}
|
|
})
|
|
|
|
if (import.meta.client) {
|
|
// eslint-disable-next-line no-console
|
|
console.log(DontRemoveThisSinceItIsUsedInSetup.props)
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.not-client {
|
|
color: "red";
|
|
}
|
|
</style>
|