vue-snippets
Vue3 Snippets, This extension adds Vue3 Code Snippets into Visual Studio Code.
Snippets
Including most of the API of Vue3. You can type reactive
, choose reactive
, and press ENTER, then const data = reactive({...})
appear on the screen.
插件的 Snippets 如下表格所示,比如你可以键入 reactive
然后按上下键选中 reactive
再按 Enter 键,就输入了const data = reactive({...})
了。
Prefix | JavaScript Snippet Content |
---|---|
import |
import {...} from "@vue/composition-api" |
import |
import {...} from 'vue' |
newVue |
newVue({...}) |
createComponent |
createComponent({...}) |
export |
export default { ... } |
setup |
setup(${...}) {...} |
reactive |
const data = reactive({...}) |
watch |
watch(..., ...) |
watchFn |
watch(() => {...}) |
computed |
computed(() => { get: () => {...}, set: () => {...}}) |
toRefs |
toRefs(...) |
ref |
ref(...) |
props |
props(...) |
onBeforeMount |
onBeforeMount(...) |
onMounted |
onMounted(...) |
onBeforeUpdate |
onBeforeUpdate(...) |
onUpdated |
onUpdated(...) |
onBeforeUnmount |
onBeforeUnmount(...) |
onUnmounted |
onUnmounted(...) |
onErrorCaptured |
onErrorCaptured(...) |
Vue Composition API
@vue/composition-api
使开发者们可以在 Vue 2.x
中使用 Vue 3.0
引入的基于函数的逻辑复用机制。
Installation
npm
yarn
CDN
By using the global variable window.vueCompositionApi.
通过全局变量 window.vueCompositionApi
来使用。
Usage
You must install @vue/composition-api via Vue.use() before using other APIs:
在使用任何 @vue/composition-api
提供的能力前,必须先通过 Vue.use()
进行安装:
After installing the plugin you can use the Composition API to compose your component.
安装插件后,您就可以使用新的 Composition API 来开发组件了。
TypeScript
This plugin requires TypeScript version >3.5.1. If you are using vetur
, make sure to set vetur.useWorkspaceDependencies
to true
.
To let TypeScript properly infer types inside Vue component options, you need to define components with createComponent
:
请使用最新版的 TypeScript,如果你使用了 vetur
,请将 vetur.useWorkspaceDependencies
设为 true
。
为了让 TypeScript 正确的推导类型,我们必须使用 createComponent
来定义组件:
TSX
? An Example Repository with TS and TSX support is provided to help you start.
To support TSX, create a declaration file with following content in your project.
? 这里有一个配置好 TS/TSX 支持的示例仓库来帮助你快速开始.
要支持 TSX,请创建一个类型定义文件并提供正确的 JSX 定义。内容如下:
Limitations
Ref
Unwrap
Unwrap
is not working with Array index.
数组索引属性无法进行自动的Unwrap
:
Should not store ref
as a direct child of Array
:
不要使用 Array
直接存取 ref
对象:
Should not use ref
in a plain object when working with Array
:
不要在数组中使用含有 ref
的普通对象:
Should always use ref
in a reactive
when working with Array:
应该总是将 ref
存放到 reactive
对象中:
Using reactive
will mutate the origin object
reactive
会返回一个修改过的原始的对象
This is an limitation of using Vue.observable
in Vue 2.
此行为与 Vue 2 中的 Vue.observable
一致
Vue 3 will return an new proxy object.
Vue 3 中会返回一个新的的代理对象.
watch()
API
onTrack
and onTrigger
are not available in WatchOptions.
不支持 onTrack
和 onTrigger
选项。
Template Refs
✅ Support ❌ Not Supported
✅ String ref && return it from setup()
:
✅ String ref && return it from setup()
&& Render Function / JSX:
❌ Function ref:
❌ Render Function / JSX in setup()
:
If you really want to use template refs in this case, you can access vm.$refs
via SetupContext.refs
.
如果你依然选择在 setup()
中写 render
函数,那么你可以使用 SetupContext.refs
来访问模板引用,它等价于 Vue 2.x 中的 this.$refs
:
⚠️ Warning: The
SetupContext.refs
won't exist inVue 3.0
.@vue/composition-api
provide it as a workaround here.
⚠️ 警告:
SetupContext.refs
并不属于Vue 3.0
的一部分,@vue/composition-api
将其曝光在SetupContext
中只是临时提供一种变通方案。
You may also need to augment the SetupContext
when working with TypeScript:
如果项目使用了 TypeScript,你还需要扩展 SetupContext
类型:
SSR
Even if there is no definitive Vue 3 API for SSR yet, this plugin implements the onServerPrefetch lifecycle hook that allows you to use the serverPrefetch hook found in the classic API.