当前位置: 首页 > wzjs >正文

广州网站建设哪家比较好青岛关键词排名提升

广州网站建设哪家比较好,青岛关键词排名提升,推荐定制型网站建设,南县做网站一、前言 在VUE项目中应用typescript,我们需要引入一个库vue-property-decorator, 其是基于vue-class-component库而来,这个库vue官方推出的一个支持使用class方式来开发vue单文件组件的库 主要的功能如下: methods 可以直接声…

在这里插入图片描述

一、前言

VUE项目中应用typescript,我们需要引入一个库vue-property-decorator

其是基于vue-class-component库而来,这个库vue官方推出的一个支持使用class方式来开发vue单文件组件的库

主要的功能如下:

  • methods 可以直接声明为类的成员方法
  • 计算属性可以被声明为类的属性访问器
  • 初始化的 data 可以被声明为类属性
  • data、render 以及所有的 Vue 生命周期钩子可以直接作为类的成员方法
  • 所有其他属性,需要放在装饰器中

二、使用

vue-property-decorator 主要提供了多个装饰器和一个函数:

  • @Prop
  • @PropSync
  • @Model
  • @Watch
  • @Provide
  • @Inject
  • @ProvideReactive
  • @InjectReactive
  • @Emit
  • @Ref
  • @Component (由 vue-class-component 提供)
  • Mixins (由 vue-class-component 提供)

@Component

Component装饰器它注明了此类为一个Vue组件,因此即使没有设置选项也不能省略

如果需要定义比如 namecomponentsfiltersdirectives以及自定义属性,就可以在Component装饰器中定义,如下:

import {Component,Vue} from 'vue-property-decorator';
import {componentA,componentB} from '@/components';@Component({components:{componentA,componentB,},directives: {focus: {// 指令的定义inserted: function (el) {el.focus()}}}
})
export default class YourCompoent extends Vue{}

computed、data、methods

这里取消了组件的data和methods属性,以往data返回对象中的属性、methods中的方法需要直接定义在Class中,当做类的属性和方法

@Component
export default class HelloDecorator extends Vue {count: number = 123 // 类属性相当于以前的 dataadd(): number { // 类方法就是以前的方法this.count + 1}// 获取计算属性get total(): number {return this.count + 1}// 设置计算属性set total(param:number): void {this.count = param}
}

@props

组件接收属性的装饰器,如下使用:

import {Component,Vue,Prop} from vue-property-decorator;@Component
export default class YourComponent extends Vue {@Prop(String)propA:string;@Prop([String,Number])propB:string|number;@Prop({type: String, // type: [String , Number]default: 'default value', // 一般为String或Number//如果是对象或数组的话。默认值从一个工厂函数中返回// defatult: () => {//     return ['a','b']// }required: true,validator: (value) => {return ['InProcess','Settled'].indexOf(value) !== -1}})propC:string;
}

@watch

实际就是Vue中的监听器,如下:

import { Vue, Component, Watch } from 'vue-property-decorator'@Component
export default class YourComponent extends Vue {@Watch('child')onChildChanged(val: string, oldVal: string) {}@Watch('person', { immediate: true, deep: true })onPersonChanged1(val: Person, oldVal: Person) {}@Watch('person')onPersonChanged2(val: Person, oldVal: Person) {}
}

@emit

vue-property-decorator 提供的 @Emit 装饰器就是代替Vue 中的事件的触发$emit,如下:

import {Vue, Component, Emit} from 'vue-property-decorator';@Component({})export default class Some extends Vue{mounted(){this.$on('emit-todo', function(n) {console.log(n)})this.emitTodo('world');}@Emit()emitTodo(n: string){console.log('hello');}}

三 、总结

可以看到上述typescript版本的vue class的语法与平时javascript版本使用起来还是有很大的不同,多处用到class与装饰器,但实际上本质是一致的,只有不断编写才会得心应手。

http://www.dtcms.com/wzjs/183505.html

相关文章:

  • 网站优化费用广州关键词快速排名
  • 股票分析软件网站建设优化关键词的正确方法
  • 日照网站开发公司网络营销是做什么的工作
  • 代理网站在线seo技巧与技术
  • 武汉哪里做网站好关键词排名查询工具有什么作用?
  • 安卓app开发培训安卓优化大师历史版本
  • 重庆网上房地产网百度seo优化推广
  • 网站备案的链接bt最佳磁力搜索引擎吧
  • 珠海做网站专业公司种子搜索神器在线搜
  • 网站的真实域名seo指的是
  • 深圳大学网站建设竞价推广平台有哪些
  • 青海玉树网站建设seo站长工具推广平台
  • 微信昵称大全沧州网站推广优化
  • wordpress storageseo网站优化方案书
  • 网站开发需要多少钱推荐网站优化资源
  • 广州公司网站开发发布软文平台
  • 网站官网建设注意seo如何优化图片
  • 芜湖建站公司百度网站推广怎么做
  • 注册公司代理网seo网站推广培训
  • 网站后端做留言板功能seo排名优化软件有
  • 不用fash做的视频网站公司管理培训课程大全
  • 淘宝客网站可以做分销吗杭州seo搜索引擎优化
  • wordpress动漫博客主题免费下载搜索引擎优化怎么做
  • 网站建设要做些什么问题seo主要优化
  • 江西网站搜索引擎优化网络广告设计
  • 怎样一个域名做两个网站八上数学优化设计答案
  • 中国建设网官方网站洞庭湖治理博客是哪个软件
  • 帮别人做网站推广犯法吗网站流量统计分析
  • 建设历史文化旅游宣传网站保定seo网站推广
  • 怎么用电脑做网站虚拟空间充电宝关键词优化