vue-property-decorator

  1. data 置顶
  2. computed 改为 get fun()
  3. 在@Emit装饰器的函数会在运行之后触发等同于其函数名(驼峰式会转为横杠式写法)的事件, 并将其函数传递给$emit
  mounted(){
    this.$on('emit-todo', function(n) {
      console.log(n)
    })
    this.emitTodo('world');
  }

  @Emit()
  emitTodo(n: string){
    console.log('hello');
  }
//触发特定的事件  带参
  @Emit('reset')
  emitTodo(n: string){
  }

4 @Watch

@Watch('child')
onChangeValue(newVal: string, oldVal: string){
    // todo...
}
@Watch('person', {immediate: true, deep: true})
onChangeValue(newVal: Person, oldVal: Person){
    // todo...
}

5 @Props

 @Prop(Number) propA!: number;
 @Prop({default: 'default value'}) propB!: string;
 @propC([String, Boolean]) propC: string | boolean;

! 是必带属性 ?是可选

6 @Model

7 Mixin

Mixins
在使用Vue进行开发时我们经常要用到混合,结合TypeScript之后我们有两种mixins的方法.

一种是vue-class-component提供的.

//定义要混合的类 mixins.ts
import Vue from 'vue';
import Component from 'vue-class-component';

@Component // 一定要用Component修饰
export default class myMixins extends Vue {
value: string = "Hello"
}
// 引入
import Component {mixins} from 'vue-class-component';
import myMixins from 'mixins.ts';

@Component
export class myComponent extends mixins(myMixins) {
// 直接extends myMinxins 也可以正常运行
created(){
console.log(this.value) // => Hello
}
}
第二种方式是在@Component中混入.

我们改造一下mixins.ts,定义vue/type/vue模块,实现Vue接口

// mixins.ts
import { Vue, Component } from 'vue-property-decorator';

declare module 'vue/types/vue' {
interface Vue {
value: string;
}
}

@Component
export default class myMixins extends Vue {
value: string = 'Hello'
}
混入

import { Vue, Component, Prop } from 'vue-property-decorator';
import myMixins from '@static/js/mixins';

@Component({
mixins: [myMixins]
})
export default class myComponent extends Vue{
created(){
console.log(this.value) // => Hello
}
}
总结: 两种方式不同的是在定义mixins时如果没有定义vue/type/vue模块, 那么在混入的时候就要继承该mixins; 如果定义vue/type/vue模块,在混入时可以在@Component中mixins直接混入.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 今天假期培训第十二天,上午一切顺利也听得非常认真,可是到了10点左右,手机自动关机了。中午找了朋友找了充电...
    吕诺爸阅读 173评论 0 0
  • 暮九安面试完后回到家中,她的养母李凤正坐在客厅的沙发上发呆,那个沙发是刚买的,很新,是深绿色的。 十七年前,十九岁...
    重逢李女侠阅读 209评论 0 0
  • 对于近一两年薛之谦在微博热搜上的次数已然是一位火的通红的巨星。 薛之谦最近录制《火星情报局》的时候曾透露自己参加综...
    陈大伯说阅读 354评论 0 1
  • 今天终于履行承诺,如约带孩子去划船‍了。而且这次不是在原来熟悉的地方,而是带他去了更大的湖边,坐了更大的船。 原本...
    上官小七阅读 285评论 0 1