vue class组件

Vue class 组件带来的优点

vue英文官网推荐了一个叫vue-class-component的包,可以以class的模式写vue组件。vue-class-component(以下简称Component)带来了很多便利:

  • methods 可以直接声明为类的成员方法,钩子都可以直接写作class的方法
  • 计算属性可以直接通过get来获得,可以被声明为类的属性访问器
  • data、render 以及所有的 Vue 生命周期可以直接作为类的成员方法
  • 所有其他属性,都可以放到Component装饰器里

Vue class 类组件的基本结构:

import Vue from ‘vue‘;
import Componet from ‘vue-class-component‘;

require(./XXX.template.scss‘);

@Component({
    template: require(./XXX.template.html‘),
    props: {
        firstName: String,
        lastName: String
    },
    components: {
        ‘component-a‘: ComponentA
    }
})
export class XXXX extends Vue {
    firstName: string;
    lastName: string;
    
    //初始data
    middleName = ‘middle‘;
    
    //computed 属性
    get fullName() {
        return this.firstName + this.lastName;
    }
    
    //method
    hello() {
        alert(`Hello ${this.fullName}!`);
    }
    
    //钩子
    mounted() {
        this.hello();
    }
}

参考

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值