vue3+ts深入组件Props

在Vue 3和TypeScript中,深入了解组件的Props是非常重要的。Props是组件之间进行数据传递的一种方式,可以将数据从父组件传递给子组件。
首先,在Vue 3中定义Props的方式有所改变。在组件的选项中,我们可以使用props属性来定义Props的类型和验证规则。例如:

import { defineComponent, PropType } from 'vue';export default defineComponent({props: {// 基本类型的Propsname: {type: String,required: true},age: {type: Number,default: 18},// 自定义类型的Propsperson: {type: Object as PropType<{ name: string, age: number }>,required: true},// 数组类型的Propshobbies: {type: Array as PropType<string[]>,default: () => []}},// ...
});

在上面的例子中,我们定义了几个不同类型的Props。name是一个必需的字符串类型的Props,age是一个可选的数字类型的Props,默认值为18。person是一个必需的自定义类型的Props,它是一个包含nameage属性的对象。hobbies是一个可选的数组类型的Props,默认值为空数组。

在使用Props时,我们可以在子组件中通过props选项来访问它们。例如:

import { defineComponent } from 'vue';export default defineComponent({props: ['name', 'age', 'person', 'hobbies'],// ...created() {console.log(this.name); // 访问字符串类型的Propsconsole.log(this.age); // 访问数字类型的Propsconsole.log(this.person); // 访问自定义类型的Propsconsole.log(this.hobbies); // 访问数组类型的Props}
});

在上面的例子中,我们通过props选项将Props声明为组件的属性。然后,在组件的created生命周期钩子中,我们可以通过this关键字来访问这些Props。

此外,还可以使用TypeScript的类型注解来提供Props的类型检查。例如:

import { defineComponent } from 'vue';interface Person {name: string;age: number;
}export default defineComponent({props: {person: {type: Object as () => Person,required: true}},// ...
});

在上面的例子中,我们使用了TypeScript的接口来定义Person类型,并在props选项中使用了类型注解来指定person的类型为Person

总结一下,在Vue 3和TypeScript中,我们可以使用props选项来定义和验证组件的Props。可以使用不同类型的Props,包括基本类型、自定义类型和数组类型。在子组件中,可以通过props选项来访问这些Props,并使用TypeScript的类型注解来提供类型检查。这样可以更安全和可靠地进行组件间的数据传递。

传递静态prop

在Vue 3和TypeScript中,如果要传递静态的Props,可以在父组件中直接在子组件的标签上使用Props的语法来传递静态值。

例如,假设我们有一个子组件ChildComponent,它有一个接受字符串类型的Props message

import { defineComponent, PropType } from 'vue';export default defineComponent({props: {message: {type: String,required: true}},// ...
});

在父组件中,可以在子组件的标签上使用Props的语法来传递静态值。

<template><div><child-component message="Hello, World!"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent}
};
</script>

在上面的例子中,我们在ChildComponent的标签上使用message属性,并传递了静态的字符串值"Hello, World!"。

在子组件中,可以通过props选项来接收传递的静态Props。

import { defineComponent } from 'vue';export default defineComponent({props: ['message'],// ...created() {console.log(this.message); // 输出:Hello, World!}
});

在上面的例子中,我们在子组件的created生命周期钩子中,通过this.message来访问传递的静态Props。

传递非字符串类型,使用v-bind

如果要传递非字符串类型的Props,并且希望使用动态的值,可以使用v-bind指令来绑定Props。

例如,假设我们有一个子组件ChildComponent,它有一个接受数字类型的Props count

import { defineComponent, PropType } from 'vue';export default defineComponent({props: {count: {type: Number,required: true}},// ...
});

在父组件中,可以使用v-bind指令来绑定Props的值。

<template><div><child-component :count="totalCount"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},data() {return {totalCount: 10};}
};
</script>

在上面的例子中,我们使用v-bind指令来绑定子组件的count属性,并将其值绑定到父组件的totalCount变量上。

在子组件中,可以通过props选项来接收传递的动态Props。

import { defineComponent } from 'vue';export default defineComponent({props: ['count'],// ...created() {console.log(this.count); // 输出:10}
});

在上面的例子中,我们在子组件的created生命周期钩子中,通过this.count来访问传递的动态Props。

prop校验,单向数据流

在Vue中,可以通过使用props选项来对Props进行校验,以确保传递给组件的数据满足特定的要求。

例如,假设我们有一个子组件ChildComponent,它有一个接受数字类型的Props count,并且要求传递的值必须大于0。

import { defineComponent, PropType } from 'vue';export default defineComponent({props: {count: {type: Number,required: true,validator: (value: number) => value > 0}},// ...
});

在上面的例子中,我们在props选项中定义了count属性,并指定了它的类型为Number,并且设置了required: true,表示这个Props是必需的。同时,我们还使用了一个自定义的校验函数validator,该函数接受传递的值作为参数,返回一个布尔值,用于校验传递的值是否满足要求。

在父组件中,如果传递的Props不满足校验要求,Vue会在控制台中输出警告信息。

<template><div><child-component :count="totalCount"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},data() {return {totalCount: -5};}
};
</script>

在上面的例子中,我们在父组件中将totalCount设置为-5,这违反了子组件的校验规则。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/62403.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习网络编程No.5【TCP套接字通信】

引言&#xff1a; 北京时间&#xff1a;2023/8/25/15:52&#xff0c;昨天刚把耗时3天左右的文章更新&#xff0c;充分说明我们这几天并不是在摆烂中度过&#xff0c;而是在为了更文不懈奋斗&#xff0c;历时这么多天主要是因为该部分知识比较陌生&#xff0c;所以需要我们花费…

Leetcode: 1. 两数之和 【题解超详细】

前言 有人夜里挑灯看花&#xff0c;有人相爱&#xff0c;有人夜里开车看海&#xff0c;有人leetcode第一题都做不出来。 希望下面的题解可以帮助你们开始 你们的 leetcode 刷题 的 天降之路 题目 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中…

测试用例的设计思考

毕业后的第一家公司个人认为除了加班巨多还是很不错的&#xff0c;我认为前司对于测试的流程和规范是非常棒的&#xff0c;对于测试用例的设计和评审都会有较高的要求。在前司的一年确实学到很多和测试流程和测试设计相关的知识。以下为自己的经验之谈&#xff0c;就是在一个模…

Java基础二十二(对集合元素排序比较)

对集合元素排序比较 1. 使用 Comparable 接口实现默认排序 Comparable 是 Java 中的一个接口&#xff0c;用于定义对象之间的排序规则。 实现了 Comparable 接口的类可以比较其对象的大小&#xff08;包装类都实现了该接口&#xff09;&#xff0c;从而可以在集合类&#xf…

JavaScript设计模式(二)——简单工厂模式、抽象工厂模式、建造者模式

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1f4c3;个人状态&#xff1a; 研发工程师&#xff0c;现效力于中国工业软件事业 &#x1f680;人生格言&#xff1a; 积跬步…

Java在线OJ项目(三)、前后端交互API模块

Java在线OJ项目&#xff08;三&#xff09;、前后端交互API模块 1. 客户端向服务器请求所有题目 或者 单个题目前端获取所有题目获取一个题目 后端 2. 后端读取前端提交的代码&#xff0c;进行编译运行&#xff0c;返回结果前端提交代码后端处理 1. 客户端向服务器请求所有题目…

Java中的Reference

1. 常用四种引用 快速记忆法&#xff1a;“硬(俗称的强引用) --> 软(SoftReference) --> 弱(WeakReference) --> 虚(PhantomReference)” 此处将常说的“强引用”记忆成“硬引用”可以对应到次席的“软引用”&#xff08;反义词&#xff1a;硬-软&#xff09;这样更容…

SAP-QM-质检操作

一、系统自动创建检验批 1、物料主数据设置 MM03-质量管理-检验设置-04来自生产收货的检验 检验类型 过账到检验库存&#xff1a;勾选进入检验库存 控制检验批&#xff1a;控制检验批的产生方式&#xff0c;按订单产生、按行产生、按凭证产生&#xff0c;例每个物料凭证项目…

C++进阶之多态

多态 多态的概念多态的定义及实现1.多态的构成条件2.虚函数3.虚函数的重写4.虚函数重写的两个例外5.C11 override 和 final6.重载、覆盖(重写)、隐藏(重定义)的对比 抽象类1.概念2.接口继承和实现继承 多态的原理1.虚函数表2.多态的原理3.动态绑定与静态绑定 单继承和多继承关系…

C++中使用 if…else 进行条件编程

C中使用 if…else 进行条件编程 在 C中&#xff0c;使用 if…else 有条件地执行代码&#xff0c;这种结构类似于下面这样&#xff1a; if (conditional expression)Do something when expression evaluates true; Else // OptionalDo something else when condition evaluate…

ArcGIS将两个相同范围但不同比例或位置的矢量数据移动到相同位置

有两个市图层&#xff0c;一个是正确经纬度的市行政范围图层&#xff0c;另一个是其他软件导出获取的不正确经纬度信息或缺失信息。 如果单纯的依靠移动图层&#xff0c;使不正确的移动到正确位置需要很久。尝试定义投影等也不能解决。 使用ArcMap 的空间校正工具条&#xff…

Python 案例实训教学,支持“教师-学生”双视角切换|ModelWhale 版本更新

学年伊始、辞旧迎新&#xff0c;金秋九月&#xff0c;ModelWhale 迎来新一轮的版本更新&#xff0c;持续优化你的使用体验。 本次更新中&#xff0c;ModelWhale 主要进行了以下功能迭代&#xff1a; • 新增 “教师-学生”双视角切换&#xff08;团队版✓&#xff09; • 新…

Stable Diffusion中的ControlNet插件

文章目录 ControlNet的介绍及安装ControlNet的介绍ControlNet的安装 ControlNet的功能介绍ControlNet的应用与演示 ControlNet的介绍及安装 ControlNet的介绍 ControlNet 的中文就是控制网&#xff0c;本质上是Stable Diffusion的一个扩展插件&#xff0c;在2023年2月份由斯坦…

Android微信数据库解密2

Android微信数据库解密2 上篇文章讲了下微信数据库密码规则,以及相关的代码. 本篇文章主要讲解下使用xpose获取对应的数据库密码. public class HookModule implements IXposedHookLoadPackage {public static final String TAG "HookModule";Overridepublic voi…

git文件夹内容详解

.git文件夹是Git版本控制系统在项目根目录下创建的隐藏文件夹&#xff0c;包含了Git仓库的所有相关信息。如下是.git文件夹中常见的一些内容及其作用&#xff1a; HEAD&#xff1a;指向当前所在的分支&#xff08;或者是一个特定的提交&#xff09;。 branches&#xff1a;存储…

详解排序算法(附带Java/Python/Js源码)

冒泡算法 依次比较两个相邻的子元素&#xff0c;如果他们的顺序错误就把他们交换过来&#xff0c;重复地进行此过程直到没有相邻元素需要交换&#xff0c;即完成整个冒泡&#xff0c;时间复杂度。 比较相邻的元素。如果第一个比第二个大&#xff0c;就交换它们两个&#xff1b;…

Spring Boot实践八--用户管理系统(下)

前面我们在数据库初始化时额外创建了一张任务表&#xff0c;用来模拟处理任务&#xff1a; key模拟业务sendMail模拟用户注册后给用户发送邮件任务&#xff0c;多线程异步任务处理analysisLog模拟每晚定时分析日志业务&#xff0c;定时任务处理 异步任务 异步任务通过方法上…

为何电商行业都在争相使用WhatsApp引流小挂件?

WhatsApp小挂件是嵌入在网站上的聊天小部件&#xff0c;允许访问者同WhatsApp与您联系。点击后&#xff0c;它会将客户带到移动或桌面 WhatsApp应用程序&#xff0c;或者直接打开一个对话框&#xff0c;客户可以在这些地方与您发起对话。让我们看看在您的网站上拥有WhatsApp聊天…

常用激活函数整理

最近一边应付工作&#xff0c;一边在补足人工智能的一些基础知识&#xff0c;这个方向虽然新兴&#xff0c;但已是卷帙浩繁&#xff0c;有时不知从何入手&#xff0c;幸亏有个适合基础薄弱的人士学习的网站&#xff0c;每天学习一点&#xff0c;积跬步以至千里吧。有像我一样学…

PHP多语言代入电商平台api接口采集拼多多根据ID获取商品详情原数据示例

拼多多商品详情原数据API接口的作用是获取拼多多电商平台上某一商品的详细信息&#xff0c;包括商品的标题、价格、库存、图片、描述、包邮信息、销量、评价、优惠券等数据。通过该API接口可以获取到商品的原始数据&#xff0c;用于分析、筛选和展示商品信息。 pinduoduo.item…