0.0.10 • Published 3 years ago
unplugin-vue-prop v0.0.10
unplugin-vue-prop
Add import define props type support for Vue3 script-setup and lang is typescript
TODO
- Support WebPack
- Support Rollup
- Support EsBuild
Usage
Basic Example
app.vue
<script setup lang="ts">
import { Demo } from './props'
defineProps<Demo>()
</script>props.ts
export interface Demo {
name: string
}Installation
npm i unplugin-vue-prop -D// vite.config.ts
import Props from 'unplugin-vue-prop/vite'
import Vue from '@vitejs/plugin-vue'
export default defineConfig({
plugins: [
Vue(),
Props()
],
})// nuxt.config.ts
export default {
buildModules: [
'unplugin-vue-prop/nuxt',
]
}Known limitations
- Namespace imports like
import * as Foo from 'foo'are not supported. - These types are not supported.
- The plugin currently only scans the content of
<script setup>. Types defined in<script>will be ignored.
Notes
Enumtypes will be converted to Union Types (e.g.type [name] = number | string) , since Vue can't handle them right now.- The plugin may be slow because it needs to read files and traverse the AST (using @babel/parser).
Caveats
- Do not reference the types themselves implicitly, it will cause infinite loop. Vue will also get wrong type definition even if you disable this plugin.
Illegal code:
export type Bar = Foo
export interface Foo {
foo: Bar
}Alternatively, you can reference the types themselves in their own definitions
Acceptable code:
export type Bar = string
export interface Foo {
foo: Foo
bar: Foo | Bar
}- Ending the type name with something like
_1and_2is not recommended, because it may conflict with the plugin's transformation result
These types may cause conflicts:
type Foo_1 = string
type Bar_2 = numberCredits
Thanks to: