mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-18 01:15:58 +00:00
feat(nuxt3): allow disabling vue type shims (#2773)
This commit is contained in:
parent
74ce059d6f
commit
f219f635ad
@ -18,9 +18,25 @@ Before getting started, please make sure you have installed the recommended setu
|
|||||||
* **Node.js**<sup>*</sup> (latest LTS version) 👉 [[Download](https://nodejs.org/en/download/)]
|
* **Node.js**<sup>*</sup> (latest LTS version) 👉 [[Download](https://nodejs.org/en/download/)]
|
||||||
* **Visual Studio Code** 👉 [[Download](https://code.visualstudio.com/)]
|
* **Visual Studio Code** 👉 [[Download](https://code.visualstudio.com/)]
|
||||||
* **Volar Extension** 👉 [[Download](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.volar)]
|
* **Volar Extension** 👉 [[Download](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.volar)]
|
||||||
|
* Either enable [**Take Over Mode**](https://github.com/johnsoncodehk/volar/discussions/471) (recommended)
|
||||||
|
* ... or add **TypeScript Vue Plugin (Volar)** 👉 [[Download](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.vscode-typescript-vue-plugin)]
|
||||||
|
|
||||||
<sup>*</sup> If you already have Node.js installed, check with `node --version` that you are using `v14` or `v16`.
|
<sup>*</sup> If you already have Node.js installed, check with `node --version` that you are using `v14` or `v16`.
|
||||||
|
|
||||||
|
::alert{type=info}
|
||||||
|
|
||||||
|
If you have enabled **Take Over Mode** or installed the **TypeScript Vue Plugin (Volar)** you can disable generating the shim for `*.vue` files:
|
||||||
|
|
||||||
|
```js
|
||||||
|
export default defineNuxtConfig({
|
||||||
|
typescript: {
|
||||||
|
shim: false
|
||||||
|
}
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
## Nuxt 3 or Bridge?
|
## Nuxt 3 or Bridge?
|
||||||
|
|
||||||
Next, decide whether to start from scratch or upgrade an existing Nuxt 2 project.
|
Next, decide whether to start from scratch or upgrade an existing Nuxt 2 project.
|
||||||
|
1
packages/nuxt3/src/app/types/index.d.ts
vendored
1
packages/nuxt3/src/app/types/index.d.ts
vendored
@ -1,5 +1,4 @@
|
|||||||
import './augments'
|
import './augments'
|
||||||
import './shims'
|
|
||||||
|
|
||||||
// eslint-disable-next-line
|
// eslint-disable-next-line
|
||||||
export * from '../index'
|
export * from '../index'
|
||||||
|
6
packages/nuxt3/src/app/types/shims.d.ts
vendored
6
packages/nuxt3/src/app/types/shims.d.ts
vendored
@ -1,6 +0,0 @@
|
|||||||
// https://github.com/vitejs/vite/blob/main/packages/create-vite/template-vue-ts/src/env.d.ts
|
|
||||||
declare module '*.vue' {
|
|
||||||
import { DefineComponent } from '@vue/runtime-core'
|
|
||||||
const component: DefineComponent<{}, {}, any>
|
|
||||||
export default component
|
|
||||||
}
|
|
@ -44,6 +44,10 @@ async function initNuxt (nuxt: Nuxt) {
|
|||||||
nuxt.hook('prepare:types', (opts) => {
|
nuxt.hook('prepare:types', (opts) => {
|
||||||
opts.references.push({ types: 'nuxt3' })
|
opts.references.push({ types: 'nuxt3' })
|
||||||
opts.references.push({ path: resolve(nuxt.options.buildDir, 'plugins.d.ts') })
|
opts.references.push({ path: resolve(nuxt.options.buildDir, 'plugins.d.ts') })
|
||||||
|
// Add vue shim
|
||||||
|
if (nuxt.options.typescript.shim) {
|
||||||
|
opts.references.push({ path: resolve(nuxt.options.buildDir, 'vue-shim.d.ts') })
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
// Init user modules
|
// Init user modules
|
||||||
|
@ -8,6 +8,19 @@ type TemplateContext = {
|
|||||||
app: NuxtApp;
|
app: NuxtApp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const vueShim = {
|
||||||
|
filename: 'vue-shim.d.ts',
|
||||||
|
write: true,
|
||||||
|
getContents: () =>
|
||||||
|
[
|
||||||
|
'declare module \'*.vue\' {',
|
||||||
|
' import { DefineComponent } from \'@vue/runtime-core\'',
|
||||||
|
' const component: DefineComponent<{}, {}, any>',
|
||||||
|
' export default component',
|
||||||
|
'}'
|
||||||
|
].join('\n')
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: Use an alias
|
// TODO: Use an alias
|
||||||
export const appComponentTemplate = {
|
export const appComponentTemplate = {
|
||||||
filename: 'app-component.mjs',
|
filename: 'app-component.mjs',
|
||||||
|
@ -10,5 +10,12 @@ export default {
|
|||||||
* You can extend generated `.nuxt/tsconfig.json` using this option
|
* You can extend generated `.nuxt/tsconfig.json` using this option
|
||||||
* @typedef {Awaited<ReturnType<typeof import('pkg-types')['readPackageJSON']>>}
|
* @typedef {Awaited<ReturnType<typeof import('pkg-types')['readPackageJSON']>>}
|
||||||
*/
|
*/
|
||||||
tsConfig: {}
|
tsConfig: {},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a `*.vue` shim.
|
||||||
|
*
|
||||||
|
* We recommend instead either enabling [**Take Over Mode**](https://github.com/johnsoncodehk/volar/discussions/471) or adding **TypeScript Vue Plugin (Volar)** 👉 [[Download](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.vscode-typescript-vue-plugin)].
|
||||||
|
*/
|
||||||
|
shim: true
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user