Vue装饰器写法-vue-class-component

Vue装饰器写法

依赖库介绍

vue-property-derocator (官方文档)

在Vue中使用TypeScript时,非常好用的一个库,使用装饰器来简化书写,下列是它提供的一下装饰器。

1.安装 npm i -S vue-property-decorator

  • @Prop
  • @PropSync
  • @Emit
  • @Model
  • @Watch
  • @Provide
  • @Inject
  • @Component(来自vue-class-component库的vue-class-component)
  • Mixins方法(来自vue-class-component库mixins)

vuex-class(官方文档)

vuex-class可以包装vuex的写法,使代码简化,它提供了4个装饰器和namespace

1.安装 npm i --save vuex-class or yarn add vuex-class

  • @State
  • @Getter
  • @Mutation
  • @Action
  • namespace

vue-class-component(官方文档)

是Vue的官方库,支持以class的方式来写vue代码,它支持下列写法

1.安装 npm i --save vue-class-component

  • methods可以直接声明类的成员方法
  • 计算属性可以被声明为类的属性访问器
  • 初始化的data可以被声明为类属性
  • data、render已经所有的Vue生命周期钩子可以作为类的成员方法
  • 提供的装饰器Component和处理mixins写法的方式mixins
  • 所有其他属性需要放在装饰器Component

导入和使用

// 导入部分
import Component, {
    mixins } from 'vue-class-component'
// 如果用到了vue-property-decorator库,建议只使用一个库导入,避免Component在项目中频繁从两个不同的库中读取
import {
    Component, Prop, Vue } from 'vue-property-decorator'

// 使用部分,@Component必写
@Component
export default class HelloWorld extends Vue {
   }

vue-class-component

装饰器写法 data与methods直接定义为类的属性即可,computed需要定义为访问器属性,mixins方法原本通过mixins属性导入改为通过继承

类组件

@Component 装饰器使您的类成为Vue组件

import Vue from 'vue'
import Component from 'vue-class-component'

// Hello 类将是vue的组建
@Component
export default class Hello extends Vue {
   }

data

@Component
export default class Hello extends Vue {
   
  // data可以直接声明为类属性
  message = 'Hello World!'
}

methods

@Component
export default class Hello extends Vue {
   
  // methods可以直接声明为类方法
  hello() {
   
    console.log('Hello World!')
  }
}
</
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,提供的引用内容中并没有涉及到Vue2和TypeScript的搭配写法。但是,我可以为您提供一些关于Vue2和TypeScript的搭配写法的信息。 在Vue2中使用TypeScript,需要安装vue-class-component和vue-property-decorator这两个库。vue-class-component提供了一个装饰@Component,可以将一个类转换为Vue组件。而vue-property-decorator则提供了一些装饰,例如@Prop、@Watch、@Emit等,可以方便地定义组件的属性、监听和事件等。 下面是一个使用Vue2和TypeScript编写的组件的示例: ``` <template> <div> 很抱歉,提供的引用内容中并没有涉及到Vue2和TypeScript的搭配写法。但是,我可以为您提供一些关于Vue2和TypeScript的搭配写法的信息。 在Vue2中使用TypeScript,需要安装vue-class-component和vue-property-decorator这两个库。vue-class-component提供了一个装饰@Component,可以将一个类转换为Vue组件。而vue-property-decorator则提供了一些装饰,例如@Prop、@Watch、@Emit等,可以方便地定义组件的属性、监听和事件等。 下面是一个使用Vue2和TypeScript编写的组件的示例: ``` <template> <div> <h1>{{ message }}</h1> <button @click="increment">Increment</button> </div> </template> <script lang="ts"> import { Component, Vue, Prop } from 'vue-property-decorator'; @Component export default class MyComponent extends Vue { @Prop({ default: 'Hello, World!' }) message!: string; count = 0; increment() { this.count++; } } </script> ``` 在这个示例中,@Component装饰将MyComponent类转换为Vue组件。@Prop装饰定义了一个名为message的属性,并指定了默认值。count属性和increment方法则直接定义在了MyComponent类中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值