位置: 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 的报错问题(解决的英文)

  • dcp7080打印机驱动安装(DCP7080打印机驱动怎么删除)

    dcp7080打印机驱动安装(DCP7080打印机驱动怎么删除)

  • 支付宝怎么充值q币(支付宝怎么充值公交卡)

    支付宝怎么充值q币(支付宝怎么充值公交卡)

  • vivos6是否有视频美颜功能(vivos6支持视频美颜吗)

    vivos6是否有视频美颜功能(vivos6支持视频美颜吗)

  • 苹果5s还能用吗(现在苹果5s还能用吗)

    苹果5s还能用吗(现在苹果5s还能用吗)

  • 抖音如果被对方拉黑还能搜索到她吗(抖音如果被对方拉黑怎么办)

    抖音如果被对方拉黑还能搜索到她吗(抖音如果被对方拉黑怎么办)

  • 飞行模式能连wifi吗(飞行模式能连airpods吗)

    飞行模式能连wifi吗(飞行模式能连airpods吗)

  • 微信被删会出现什么字(微信被删除了还会出现在好友列表吗)

    微信被删会出现什么字(微信被删除了还会出现在好友列表吗)

  • 华为直播精灵怎么用(华为直播精灵怎么安装)

    华为直播精灵怎么用(华为直播精灵怎么安装)

  • 电脑没有电池能用吗(电脑没有电池可以直接插电用吗)

    电脑没有电池能用吗(电脑没有电池可以直接插电用吗)

  • 怎么登录快手(怎么登录快手极速版)

    怎么登录快手(怎么登录快手极速版)

  • 苹果xr卡槽哪个是主卡(苹果xr卡槽哪个放电信好)

    苹果xr卡槽哪个是主卡(苹果xr卡槽哪个放电信好)

  • 微信屏蔽是什么意思(微信屏蔽是什么心理)

    微信屏蔽是什么意思(微信屏蔽是什么心理)

  • 智能助理是什么(智能助理是什么意思)

    智能助理是什么(智能助理是什么意思)

  • xsmax双卡怎么弄(xsmax双卡如何设置)

    xsmax双卡怎么弄(xsmax双卡如何设置)

  • 手机wps怎么删多余ppt(手机wps怎么删除多个文档)

    手机wps怎么删多余ppt(手机wps怎么删除多个文档)

  • 什么是悬浮窗(什么是悬浮窗?)

    什么是悬浮窗(什么是悬浮窗?)

  • 苹果xr老是断网怎么解决(苹果xr手机老是断网怎么回事)

    苹果xr老是断网怎么解决(苹果xr手机老是断网怎么回事)

  • 有道怎么设置锁屏单词(有道怎么设置桌面快捷翻译)

    有道怎么设置锁屏单词(有道怎么设置桌面快捷翻译)

  • 怎么查三星手机是不是原装(怎么查三星手机是不是原装正品)

    怎么查三星手机是不是原装(怎么查三星手机是不是原装正品)

  • 128g内存卡怎么看真假(128G内存卡怎么能知道)

    128g内存卡怎么看真假(128G内存卡怎么能知道)

  • 大疆御1和2区别(大疆御1和2参数对比)

    大疆御1和2区别(大疆御1和2参数对比)

  • word分隔线怎么弄(word分隔线怎么加入)

    word分隔线怎么弄(word分隔线怎么加入)

  • mediapassk.exe是什么进程 有什么用 mediapassk进程查询(mediabrowser.exe是什么)

    mediapassk.exe是什么进程 有什么用 mediapassk进程查询(mediabrowser.exe是什么)

  • phpcms v9判断用户是否登录(php判断数据库用户名是否存在)

    phpcms v9判断用户是否登录(php判断数据库用户名是否存在)

  • 小规模纳税人享受1%的税率
  • 小规模纳税人工程款税率是多少
  • 装卸费发票怎么备注
  • 内账会计会承担法律责任吗
  • 电脑填制记账凭证实训心得
  • 凭证附件的粘法
  • 过路费纸质发票怎么生成电子发票
  • 签章是签字还是盖章 财务
  • 发票到了款未付账务处理
  • 缓缴税款到期缴纳罚款吗
  • 劳动竞赛费用在什么科目列支做会计分录?
  • 什么是增值税差额征税政策
  • 公交补贴收入账务处理怎么做?
  • 如何处理没有录音的人
  • 工伤保险可以税后支付吗
  • 企业所得税汇算清缴时间
  • 国税电子钥匙常见问题解答
  • 长期股权投资的初始计量
  • 长期应付款账面价值和账面余额
  • 银行存款余额调节表保管期限
  • 宣传活动物资
  • 股东赠与计入资本公积,交税
  • 暂估入库价格高于实际价格怎么调整
  • 企业销售收入含不含税
  • 公司解散实收资本退还怎么写
  • 长期资产的含义
  • 费用开两次发票怎么入账?
  • 加速折旧法和直线折旧法的区别
  • 损益类科目在期末均需转入什么科目
  • 汇算清缴租赁费包括物业管理吗
  • window11 正式版
  • dns进程
  • PHP:curl_multi_remove_handle()的用法_cURL函数
  • 总部资产减值测试例题
  • 高新企业研发费用占比规定
  • 减免税款怎么做账务处理
  • 若依前后端分离做的系统
  • php日期差数
  • 解决的英文
  • 捐赠所得属于什么会计科目
  • 电子发票能否作废
  • 非贸付汇代扣代交哪些税
  • 应收账款和其他应收款的区别
  • yolov5目标检测流程图
  • 抖音是如何成功的
  • 十大经典排序算法(动图演示C 实现)
  • vue中key
  • php点运算符
  • mdadm命令用不了
  • 怎么样写合同书
  • 禁止DedeCMS未审核文档支持动态浏览方法
  • 发票冲红如何进入系统
  • 预付卡账务处理在注会
  • 什么是存货周转期间
  • 用友结算成本处理在哪里
  • 用于捐赠的会计处理
  • 期末汇兑损益的输入方式
  • 电脑配件入账
  • 应收帐款周转率计算公式为
  • 施工单位购买材料能直接进成本吗
  • 劳务派遣证验资
  • 每月分红会计分录
  • 怎么开劳务派遣工作证明
  • SQLServer XML数据的五种基本操作
  • mysql的表文件在哪
  • 备份数据还原不了怎么办
  • 设置共享时可使用的权限
  • 注册表干嘛用
  • WIN10系统更新之后无法启动
  • 怎么安装u盘里的文件
  • window10自带录屏录制不工作
  • win10创建系统还原点有什么用
  • WIN10任务栏时间不动
  • macbook编译java
  • json对象如何取值
  • 如何ssh登陆
  • Android Toast设置弹窗大小
  • jquery.validate 自定义验证方法及validate相关参数
  • unity 3d游戏开发
  • 实际金额与报关金额不符
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设