位置: IT常识 - 正文

vue3 props属性基本使用梳理(vue3中props)

编辑:rootadmin
vue3 props属性基本使用梳理 前言

推荐整理分享vue3 props属性基本使用梳理(vue3中props),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue property属性,vue的props属性,vue中props值怎么在方法中使用,vue3中props,vue property属性,vue3中props,vue的props属性,vue3中props,内容如对您有帮助,希望把文章链接给更多的朋友!

vue2中props属性的使用是比较统一的基本就一种方式,但是vue3中其实方式是比较多的,因此就打算梳理一下。 会按照选项式和组合式进行梳理,包括属性的定义、取值以及属性的监听。

应该是叫单文件组件和组合式API,不知道vue官方是根据什么区分的。

单文件组件定义

这里大体上分为两大类进行说明,这两大类都需要使用defineProps来进行定义

非ts语法const props = defineProps({ // 基础类型检查 // (给出 `null` 和 `undefined` 值则会跳过任何类型检查) propA: Number, // 多种可能的类型 propB: [String, Number], // 必传,且为 String 类型 propC: { type: String, required: true }, // Number 类型的默认值 propD: { type: Number, default: 100 }, // 对象类型的默认值 propE: { type: Object, // 对象或数组的默认值 // 必须从一个工厂函数返回。 // 该函数接收组件所接收到的原始 prop 作为参数。 default(rawProps) { return { message: 'hello' } } }, // 自定义类型校验函数 propF: { validator(value) { // The value must match one of these strings return ['success', 'warning', 'danger'].includes(value) } }, // 函数类型的默认值 propG: { type: Function, // 不像对象或数组的默认,这不是一个工厂函数。这会是一个用来作为默认值的函数 default() { return 'Default function' } }})

这种方式还是比较简单的,基本和vue2没有太大的区别。

ts语法interface ganttChartItem { // 宽度 width: number, // 颜色 color: string}interface Props { // id id:string // 宽度 width: number, // 高度 height?: number, // 是否初始化 init?: boolean, // 子项 list?: Array<ganttChartItem>, // 是否显示描述 desc?:string // 描述颜色 descColor?:string}const props = withDefaults(defineProps<Props>(), { // 高度默认20 height: 20, // 默认初始化 init: true, // 子项默认为空 list: () => [], // 是否显示描述 desc: '', // 描述颜色 descColor: ''});vue3 props属性基本使用梳理(vue3中props)

特殊点:

泛型,可以通过定义interface接口来规范props的属性的格式。不像vue2中定义一个对象类型的属性,这个对象中可以有各种各样的子属性。?: 表示可选属性,:表示必填属性定义默认属性值时需要使用withDefaults取值

取值时可以当成一个普通的对象,例如:

props.desc监听watch( () => props.visible, (val) => { open.value = val; console.log(val); });demo<a-b v-model:visible="show" />//ab.vue<template> <div class="container"> <el-dialog v-model="open" title="Tips" width="30%"> <span>This is a message</span> </el-dialog> </div></template><script setup lang="ts">import { watch, ref } from 'vue';const props = defineProps({ visible: { type: Boolean, default: false }});const open = ref(false);watch( () => props.visible, (val) => { open.value = val; console.log(val); });</script>

这里有个问题,虽然弹窗绑定的值可以直接是属性,但是好像不推荐这样使用

组合式

感觉setup语法糖模式用的更多一点(可能是我们公司用的比较多)。好久没这样用了,差点忘记怎么写了😀

定义

这个没什么说的,跟vue2一样

props: { visible: { type: Boolean, default: false } },使用

使用时需要通过setup函数传参的方式来取值。

setup(props) { return { props }; }监听 watch( () => props.visible, (val) => { open.value = val; console.log(val); } );demo<template> <div> <el-dialog v-model="open" title="Tips" width="30%"> <span>This is a message</span> </el-dialog> </div></template><script lang="ts">import { defineComponent, watch, ref } from 'vue';export default defineComponent({ props: { visible: { type: Boolean, default: false } }, setup(props) { const open = ref(false); watch( () => props.visible, (val) => { open.value = val; console.log(val); } ); return { open }; }});</script>补充

其实没必要非要用props属性,props属性应该在该用的时候用。

可以看一下我的这篇文章:vue3:使用ref和emit来减少props的使用

本文链接地址:https://www.jiuchutong.com/zhishi/290791.html 转载请保留说明!

上一篇:南奥索峰的Lac d'Ayous小屋,法国 (© Eneko Aldaz/Offset by Shutterstock)

下一篇:解决:code ERESOLVE:ERESOLVE could not resolve 的报错问题(解决的英文)

  • oppo手机怎么退出分屏模式(oppo手机怎么退出界面)

    oppo手机怎么退出分屏模式(oppo手机怎么退出界面)

  • word拐弯箭头怎么去掉(word拐弯箭头怎么做)

    word拐弯箭头怎么去掉(word拐弯箭头怎么做)

  • 旺信怎么加好友(旺信怎么登陆)

    旺信怎么加好友(旺信怎么登陆)

  • 小米mix3慢动作在哪里(小米mix3慢动作摄影怎么拍摄)

    小米mix3慢动作在哪里(小米mix3慢动作摄影怎么拍摄)

  • vivox30死机该如何解决(vivo手机死机了)

    vivox30死机该如何解决(vivo手机死机了)

  • 华为mate20pro不贴膜行吗(华为mate20pro不贴膜)

    华为mate20pro不贴膜行吗(华为mate20pro不贴膜)

  • 苹果怎么锁定屏幕不动(苹果怎么锁定屏幕编辑)

    苹果怎么锁定屏幕不动(苹果怎么锁定屏幕编辑)

  • 扁头耳机插上去没声音(扁头耳机插上去没反应怎么设置)

    扁头耳机插上去没声音(扁头耳机插上去没反应怎么设置)

  • 华为型号SEAAL10什么意思(华为型号大全对照图)

    华为型号SEAAL10什么意思(华为型号大全对照图)

  • 微信零钱明细删除了还能恢复吗(微信零钱明细删除了怎么还有记录)

    微信零钱明细删除了还能恢复吗(微信零钱明细删除了怎么还有记录)

  • 手机充电格变黄是什么原因(手机充电格变黄色怎么办)

    手机充电格变黄是什么原因(手机充电格变黄色怎么办)

  • 网易黑胶和音乐包区别(网易黑胶音乐下载)

    网易黑胶和音乐包区别(网易黑胶音乐下载)

  • 笔记本电脑可以用充电宝充电吗?(笔记本电脑可以换显卡吗)

    笔记本电脑可以用充电宝充电吗?(笔记本电脑可以换显卡吗)

  • 苹果7怎么弄人脸解锁(苹果怎么弄人脸识别下载应用)

    苹果7怎么弄人脸解锁(苹果怎么弄人脸识别下载应用)

  • 找不到投屏设备怎么办(为什么视频找不到投屏设备)

    找不到投屏设备怎么办(为什么视频找不到投屏设备)

  • 手机qq自动回复无效(手机qq自动回复怎么设置)

    手机qq自动回复无效(手机qq自动回复怎么设置)

  • oppor11长度多少厘米(oppor11的长度和宽度)

    oppor11长度多少厘米(oppor11的长度和宽度)

  • 苹果充电电量一直不变(苹果充电电量一直在变)

    苹果充电电量一直不变(苹果充电电量一直在变)

  • qq显示忙碌还能聊天吗(qq显示忙碌是啥意思)

    qq显示忙碌还能聊天吗(qq显示忙碌是啥意思)

  • 华为p20可以熄屏显示吗(华为p20如何设置灭屏显示)

    华为p20可以熄屏显示吗(华为p20如何设置灭屏显示)

  • 淘气值多少能享有极速退款(淘气值等于多少钱)

    淘气值多少能享有极速退款(淘气值等于多少钱)

  • 什么叫反激活设备(反激活教程)

    什么叫反激活设备(反激活教程)

  • 共享单车使用结束怎么操作(共享单车使用结束后正确的方法有)

    共享单车使用结束怎么操作(共享单车使用结束后正确的方法有)

  • ipad 4g可以打电话吗(ipad 4g可以接电话吗)

    ipad 4g可以打电话吗(ipad 4g可以接电话吗)

  • applewatch强制重置(applewatch强制重启白苹果变红苹果)

    applewatch强制重置(applewatch强制重启白苹果变红苹果)

  • ags2-w09是什么型号(ags2-l09是什么型)

    ags2-w09是什么型号(ags2-l09是什么型)

  • 【vue2可视化开发】新手会遇到的问题——大屏自适应(vue可视化面板怎么打开)

    【vue2可视化开发】新手会遇到的问题——大屏自适应(vue可视化面板怎么打开)

  • 【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组 | 精品题解(蓝桥杯2021出结果)

    【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组 | 精品题解(蓝桥杯2021出结果)

  • 销售赠送赠品会计处理
  • 固定资产清理残料变价收入
  • 无形资产摊销计算例题
  • 增值税和个人所得税都要交吗
  • 广告发布费在哪个分类
  • 买金税盘发票能全额抵进项税吗
  • 城市规划部门收取的市政建设配套费是否作为契税的征税基数
  • 委托外单位加工发出的材料分录
  • 电商刷单返现如何做账务处理合适?
  • 生产质量问题报告怎么写
  • 对以前年度的收入调整
  • 借贷记账法要求对某一笔经济业务在两个账户
  • 物业收取水费比水厂收的高怎么办
  • 国税一个月没报税罚款多少
  • 所得税申报错了扣款了怎么办
  • 出售房产收入计入什么科目
  • 个税纳税期数如何规定的 怎么选择
  • 印花税计提和缴纳凭证
  • 高新企业境外所得缴纳企业所得税税率为多少
  • 6%技术服务费是普票还是专票
  • 网络唤醒的原理
  • 公司投资理财产品
  • php glob
  • php解构
  • vue 高德地图 窗体
  • 收到退款的会计分录
  • Madonna della Corona教堂,意大利 (© Volodymyr Kalyniuk/Alamy)
  • 资本公积转增注册资本的条件
  • 会计准则对企业行为的影响分析论文
  • thinkphp 模板标签
  • linux系统操作教程
  • tensorflow theano
  • 工会经费税前扣除是什么意思
  • 弥补以前年度亏损报表怎么填
  • 本月确认收入 发票下月开
  • python insert方法
  • 什么是服务型
  • 费用票有什么用处
  • 滴滴票可以抵扣吗?
  • 本月进项税额可以下月抵扣吗
  • 固定资产的入账金额怎么算
  • 技术使用费所得怎么算
  • 企业回购股票会退市吗
  • 公户网银丢了
  • SqlServer2012中First_Value函数简单分析
  • 差旅费报销时如何处理
  • 调整以前年度费用怎么做账
  • 全资子公司变成孙公司是利好吗?
  • 垫款报销
  • 老板请员工吃饭的文案
  • 农产品加计扣除1%怎么计算和会计分录
  • 公司的软件服务器设置什么意思啊
  • centos yun
  • mysql数据库操作题
  • centos访问网页命令
  • ubuntu ifdown
  • ubuntu 无线wifi
  • win1021h2正式版
  • macbookpro屏幕显示
  • thinkpad笔记本键盘无法输入
  • linux将文本写入文件
  • win7怎么设置工作组共享
  • unity 3d
  • 每日十条简短新闻
  • 激发灵感的三种方式是什么
  • css网站布局实录 pdf
  • 使用Math.floor与Math.random取随机整数的方法详解
  • bootstrap js插件
  • jquery库有哪些
  • 关于学习的名言
  • jQuery插件扩展extend的简单实现原理
  • 顺丰收取关税合理吗
  • 房产税的计税依据及税率
  • 辽宁社保网上申报流程图
  • 运输服务费税率9%还是6%
  • 云南国税通用发票查询
  • 上海税务门户网站
  • 顺德中学校徽图片大全1998年
  • 矿产资源税怎样征收
  • 国税商品分类目录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设