备注: 代码中 el-* 的标签是 ElementUI 的组件。

一、@Component 装饰器

@Component 装饰器是用以声明子组件。

1)父组件

	<template>
<div>
<h1>@Component - 声明(引入)组件</h1>
<ComponentSub></ComponentSub>
</div>
</template> <script lang="ts">
import { Component, Vue } from 'vue-property-decorator';
import ComponentSub from '@/components/decorator/other_decorator/ComponentSub.vue'; @Component({ components: { ComponentSub } })
export default class Home extends Vue { }
</script>

2)子组件

	<template>
<p>这是子组件</p>
</template> <script lang="ts">
import { Component, Vue } from 'vue-property-decorator'; @Component
export default class ComponentSub extends Vue { }
</script>

二、 @Emit 装饰器

@Emit 装饰器是用以子组件触发父组件的自定义事件。

1)父组件

	<template>
<div>
<h1>@Emit - 子组件触发父组件的自定义事件</h1>
<EmitSub @bind-no-arg="welcomeNoArg" @welcome="sayHi"></EmitSub>
</div>
</template> <script lang="ts">
import { Component, Vue } from 'vue-property-decorator';
import EmitSub from '@/components/decorator/property_decorator/EmitSub.vue'; @Component({ components: { EmitSub } })
export default class Prop extends Vue {
private welcomeNoArg(): void {
console.log(111);
} private sayHi(arg: string[]): void {
console.log(arg);
alert(arg[0]);
}
}
</script>

2)子组件

<template>
<div>
<el-row>
<el-button @click="bindNoArg">无返回值</el-button>
<el-button @click="bindHaveArg">无返回值</el-button>
</el-row>
</div>
</template> <script lang="ts">
import { Component, Prop, Vue, Emit } from 'vue-property-decorator'; @Component
export default class HelloWorld extends Vue {
@Emit() private bindNoArg(): void {
console.log('bindNoArg');
} @Emit('welcome') private bindHaveArg(): string[] {
console.log('bindHaveArg');
return ['Yes', 'No', 'Maybe'];
}
}
</script>

三、 @Model 装饰器

@Model 装饰器是用以组件上实现双向绑定。

1)父组件

	<template>
<div>
<h1>@Model - 组件上实现双向绑定</h1>
<el-button type="primary" @click="onAlterFoo">父组件改变foo</el-button>
<ModelSub v-model="foo"></ModelSub>
</div>
</template> <script lang="ts">
import { Vue, Component, Model } from 'vue-property-decorator';
import ModelSub from '@/components/decorator/property_decorator/ModelSub.vue'; @Component({ components: { ModelSub } })
export default class ModelComponent extends Vue {
private foo: boolean = true; private onAlterFoo() {
this.foo = !this.foo;
}
}
</script>

2)子组件

	<template>
<div>
<input type="checkbox" v-bind:checked="checked"
v-on:change="$emit('balabala', $event.target.checked)"
>
</div>
</template> <script lang="ts">
import { Vue, Component, Model, Prop } from 'vue-property-decorator'; @Component
export default class ModelComponent extends Vue {
@Model('balabala', { type: Boolean }) private checked!: boolean;
}
</script>

四、 @Prop 装饰器

@Prop 装饰器是用以接收来自父组件的数据。

1)父组件

	<template>
<div>
<h1>@Prop - 接收来自父组件的数据</h1>
<PropSub msg="中野三玖"></PropSub>
</div>
</template> <script lang="ts">
import { Component, Vue, Emit, Inject } from 'vue-property-decorator';
import PropSub from '@/components/decorator/property_decorator/PropSub.vue'; @Component({ components: { PropSub } })
export default class Prop extends Vue { }
</script>

2)子组件

<template>
<div>
这是子组件收到的值:{{ msg }}
</div>
</template> <script lang="ts">
import { Component, Prop, Vue } from 'vue-property-decorator'; @Component
export default class HelloWorld extends Vue {
@Prop() private msg!: string; // ! 表示确定msg有值
}
</script>

五、 @Provide 装饰器 和 @Inject 装饰器

@Provide 装饰器是用以注入数据,@Inject 装饰器是用以获取注入的数据。

1)父组件 @Provide

	<template>
<div>
<h1>@Provide/@Inject - 接收来自父组件的数据</h1>
父组件通过依赖注入赋予的值是:{{ foo }}
<ProvideInject></ProvideInject>
</div>
</template> <script lang="ts">
import { Component, Vue, Provide } from 'vue-property-decorator';
import ProvideInject from '@/components/decorator/property_decorator/ProvideInject.vue'; @Component({ components: { ProvideInject } })
export default class Home extends Vue {
@Provide('bar') private foo = '111';
}
</script>

2)子组件 @Inject

<template>
<div>
子组件通过依赖注入接收的值是:{{ bar }}
</div>
</template> <script lang="ts">
import { Component, Vue, Inject } from 'vue-property-decorator'; @Component
export default class ProvideInject extends Vue {
@Inject() private readonly bar!: string;
}
</script>

六、 @Watch 装饰器

@Watch 装饰器是用以监控数据是否改变。

	<template>
<div>
<h1>@Watch - 监控数据是否改变</h1>
<el-input v-model="child" placeholder="请输入内容"></el-input>
<p>当前值:{{ val }} 原来值:{{ oldVal }}</p>
</div>
</template> <script lang="ts">
import { Component, Vue, Inject, Watch } from 'vue-property-decorator'; @Component
export default class ProvideInject extends Vue {
private child: number | null = null;
private val: number | null = null;
private oldVal: number | null = null; @Watch('child')
private onChildChanged(val: number, oldVal: number): void {
this.val = val;
this.oldVal = oldVal;
}
}
</script>

参考文档 :

使用 Vue + TypeScript 时项目中常用的装饰器的更多相关文章

  1. 项目中常用的MySQL 优化

    本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下: 一.EXPLAIN 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划. 下面来个简单的示例,标注(1.2.3.4.5)我 ...

  2. JAVA项目中常用的异常处理情况总结

    JAVA项目中常用的异常知识点总结 1. java.lang.nullpointerexception这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用 ...

  3. JAVA项目中常用的异常知识点总结

    JAVA项目中常用的异常知识点总结 1. java.lang.nullpointerexception这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用 ...

  4. ES6系列之项目中常用的新特性

    ES6系列之项目中常用的新特性 ES6常用特性 平时项目开发中灵活运用ES6+语法可以让开发者减少很多开发时间,提高工作效率.ES6版本提供了很多新的特性,接下来我列举项目中常用的ES6+的特性: l ...

  5. 在Vue&Element前端项目中,对于字典列表的显示处理

    在很多项目开发中,我们为了使用方便,一般都会封装一些自定义组件来简化界面的显示处理,例如参照字典的下拉列表显示,是我们项目中经常用到的功能之一,本篇随笔介绍在Vue&Element前端项目中如 ...

  6. Android 项目中常用到的第三方组件

    项目中常用到的第三方组件 1 社会化分享ShareSDK-Core-2.5.9.jarShareSDK-QQ-2.5.9.jarShareSDK-QZone-2.5.9.jarShareSDK-Sin ...

  7. 项目中常用js方法整理common.js

    抽空把项目中常用js方法整理成了common.js,都是网上搜集而来的,大家一起分享吧. var h = {}; h.get = function (url, data, ok, error) { $ ...

  8. 记录下项目中常用到的JavaScript/JQuery代码二(大量实例)

    记录下项目中常用到的JavaScript/JQuery代码一(大量实例) 1.input输入框监听变化 <input type="text" style="widt ...

  9. VB的一些项目中常用的通用方法-一般用于验证类

    1.VB的一些项目中常用的通用方法: ' 设置校验键盘输入值,数字 Public Function kyd(key As Integer) As Integer Dim mychar mychar = ...

随机推荐

  1. 学习记录:《C++设计模式——李建忠主讲》3.“组件协作”模式

    “组件协作”模式:现代软件专业分工之后的第一个结果是“框架与应用程序的划分”,“组件协作”模式通过晚期绑定,来实现框架与应用程序之间的松耦合,是二者之间协作时常用的模式.典型模式:Template M ...

  2. 物联网架构成长之路(47)-利用GitLab实现CI持续集成

    0.前言 前段时间,考虑到要练习部署一套CI/CD的系统.一开始考虑到Jenkins,随着这两天的了解,发现最新版的GitLab已经提供有CI/CD集成了.所以本次博客,干脆一步到位,直接用GitLa ...

  3. Coding,命名是个技术活

    来吧 日常编码少不了的事情就是给代码命名,代码中命名的重要性在项目前期不会有太大感受,因为是边做边命名,代码天天见,自然会加深记忆.但到了后期上线后半年一年后,再回过头看的时候,我擦,这个变量是啥意思 ...

  4. /etc/security/limits.conf 详解与配置

    目录 一. /etc/security/limits.conf 详解 /etc/security/limits.conf 配置解析 /etc/security/limits.d/ 目录 二. ulim ...

  5. Caffe 图像分类

      本文主要描述如何使用 CAFFE 进行图像分类. 开发环境要求:windows 10 64位.Visual Studio 2017..NET framework 4.6.1     分类 在一个项 ...

  6. [ASP.NET Core 3框架揭秘] 配置[1]:读取配置数据[上篇]

    提到"配置"二字,我想绝大部分.NET开发人员脑海中会立即浮现出两个特殊文件的身影,那就是我们再熟悉不过的app.config和web.config,多年以来我们已经习惯了将结构化 ...

  7. Python实现简单框架及三大框架对比

    手撸web框架 简单的请求响应实现 要实现最简单的web框架,首先要对网络熟悉,首先HTTP协议是应用层的协议,只要我们给数据加上HTTP格式的响应报头,我们的数据就能基于socket进行实现了 im ...

  8. Apache和PHP结合、Apache默认虚拟主机

    5月28日任务 课程内容: 11.14/11.15 Apache和PHP结合11.16/11.17 Apache默认虚拟主机 11.14/11.15 Apache和PHP结合 到目前为止虽然安装好了A ...

  9. 设置更改root密码、连接mysql、mysql常用命令

    6月19日任务 13.1 设置更改root密码13.2 连接mysql13.3 mysql常用命令 13.1 设置更改root密码 使用场景:例如长时间不用忘记了mysql的root密码,那么就需要去 ...

  10. iText + Freemarker实现pdf的导出,支持中文、css以及图片,页眉页脚,页眉添加图片

    本文为了记录自己的实现过程,具体的实现步骤是参考博文 https://www.cnblogs.com/youzhibing/p/7692366.html 来实现的,只是在他的基础上添加了页眉页脚及页眉 ...