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

  • 小米公司简介是硬件公司,还是互联网公司

    小米公司简介是硬件公司,还是互联网公司

  • morphvox pro参数(morphvox pro怎么用)(morphvox pro手机可以用吗)

    morphvox pro参数(morphvox pro怎么用)(morphvox pro手机可以用吗)

  • 软件开源和不开源的区别(开源软件是)

    软件开源和不开源的区别(开源软件是)

  • 荣耀30pro是几个颜色(荣耀30pro几个送话器)

    荣耀30pro是几个颜色(荣耀30pro几个送话器)

  • 飞机apu是什么东西(apu飞机上什么意思)

    飞机apu是什么东西(apu飞机上什么意思)

  • 检测到闪电接口有液体(检测到闪电接口有液体无法充电)

    检测到闪电接口有液体(检测到闪电接口有液体无法充电)

  • 苹果耳机左耳感叹号(苹果耳机左耳感觉有杂音)

    苹果耳机左耳感叹号(苹果耳机左耳感觉有杂音)

  • 学信网密码和密保问题都忘记了怎么办(学信网密码和密码是什么)

    学信网密码和密保问题都忘记了怎么办(学信网密码和密码是什么)

  • vivo x50 pro上市时间(vivo x50 pro发售价)

    vivo x50 pro上市时间(vivo x50 pro发售价)

  • qq能不能隐藏某个人的火花(qq能不能隐藏某个人信息)

    qq能不能隐藏某个人的火花(qq能不能隐藏某个人信息)

  • 华为荣耀9xpro怎么截屏(华为荣耀9Xpro怎么把手机号码导入卡里)

    华为荣耀9xpro怎么截屏(华为荣耀9Xpro怎么把手机号码导入卡里)

  • 打着语音电话闹钟会响吗(打着语音电话闹钟会响吗安卓)

    打着语音电话闹钟会响吗(打着语音电话闹钟会响吗安卓)

  • 抖音视频播放量低什么原因(抖音视频播放量有收益吗)

    抖音视频播放量低什么原因(抖音视频播放量有收益吗)

  • 华为p30pro手电筒在哪里(华为p30pro手电筒打不开怎么办)

    华为p30pro手电筒在哪里(华为p30pro手电筒打不开怎么办)

  • 苹果手机可以下载抖音极速版吗(苹果手机可以下载vivo应用商店吗)

    苹果手机可以下载抖音极速版吗(苹果手机可以下载vivo应用商店吗)

  • 手机语言怎么切换中文(手机语言怎么切换)

    手机语言怎么切换中文(手机语言怎么切换)

  • mate30新机自带膜吗(mate30 自带膜)

    mate30新机自带膜吗(mate30 自带膜)

  • 电脑excel怎么下载

    电脑excel怎么下载

  • 美图秀秀电脑版怎么下载(美图秀秀电脑版下载)

    美图秀秀电脑版怎么下载(美图秀秀电脑版下载)

  • 华为p30pro耳机孔在哪里(华为p30pro耳机孔演示)

    华为p30pro耳机孔在哪里(华为p30pro耳机孔演示)

  • 怎样把商品放到抖音橱窗(怎样把商品放到闲鱼上卖)

    怎样把商品放到抖音橱窗(怎样把商品放到闲鱼上卖)

  • 京东退货卖家不审核怎么办(京东退货卖家不同意怎么办)

    京东退货卖家不审核怎么办(京东退货卖家不同意怎么办)

  • 隔空投送成功找不到照片(隔空投送已发送但手机里找不到)

    隔空投送成功找不到照片(隔空投送已发送但手机里找不到)

  • 荣耀10怎么才能熄屏显示时间(荣耀怎么才能开出shr)

    荣耀10怎么才能熄屏显示时间(荣耀怎么才能开出shr)

  • 手机qq怎么改名字昵称(手机qq怎么改名字换头像)

    手机qq怎么改名字昵称(手机qq怎么改名字换头像)

  • 老年机为什么打不出去电话(老年机为什么打过去是关机)

    老年机为什么打不出去电话(老年机为什么打过去是关机)

  • 增值税专用发票怎么开
  • 固定资产处置营业外收入和发票金额不一致
  • 金税盘税务申报
  • 食堂买菜费用如何做会计
  • 旅游业差额开票怎么做账
  • 什么是非限制
  • 公司团体体检的洽谈
  • 印花税小于1元显示无需申报
  • 机票的差额发票可以报销吗
  • 设备租赁公司是干嘛的
  • 暂估成本结转后怎么冲回
  • 由财政拨钱还银行借款怎么做分录?
  • 我国进口货物交税如何计算? 
  • 进项税额转出是不可以抵扣吗
  • 营业外收入交税会计分录
  • 培训费的进项需要转出吗
  • 财产租赁合同印花税申报期限
  • 生物性资产是什么
  • 生产成本为什么不属于费用
  • 无票收入冲回会计分录
  • 企业注销时未分配利润怎么处理
  • 对公汇款银行退回
  • mac dock不见了
  • 总公司以固定资产出资入股,固定资产是不是新公司的
  • win10远程连接提示身份验证错误
  • php变量设置
  • player.exe是什么意思
  • linux中怎么安装GUI
  • 你知道约定的公司有哪些
  • linux 分享文件
  • 原材料赔偿会计分录
  • 用科目汇总表怎么登记总账
  • protect.exe进程
  • 显示器显示频率设置
  • 采购员出差预借差旅费时,应借记
  • 富士山的岩石属于什么岩
  • 预缴企业所得税分录
  • php使用pclzip类实现文件压缩的方法(附pclzip类下载地址)
  • 对公贷款利息支付
  • 账本登错的账务如何处理
  • bootstrap 栅格
  • mdadm命令详解
  • 专项资金怎么填表
  • 关于公司预支工资制度
  • 业务招待费调增额怎么算
  • 固定资产处置收入增值税税率
  • 企业收入总额的计算公式
  • canvas实现图片编辑
  • html导航链接
  • 如何准确理解nosql的含义?
  • python3 tcp
  • 饲料加工企业可以转让吗
  • SQL查询中in和exists的区别分析
  • sql 列转行
  • mysql数据表分区
  • 办公室装修用什么材料便宜
  • 以前年度损益调整账务处理分录
  • 还借款收据怎么写
  • 车辆etc设备
  • 售后维修费会计分录
  • 分支机构与总机构怎么纳税?
  • 营改增对企业税负影响
  • 商品验收入库时怎么做账
  • 对公账户可以取钱出来吗
  • sql语句错误提示
  • sql多表连接查询(详细实例)
  • win7系统IE浏览器版本
  • ie10工具栏在哪
  • gnaupdaemon.exe是什么
  • win10重置系统快捷键
  • Win10怎么安装软件
  • win8打不开咋办
  • jquery prompt
  • 合并多个js文件
  • Android--VideoPlay--视频播放器
  • 叠加计算公式
  • 下拉列表框模糊匹配
  • javascript面向对象编程
  • 中国税务稽查官网
  • 江苏省国家税务总局江苏省电子税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设