news 2026/2/22 17:19:09

vue中的props详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue中的props详解

一、props 的作用与设计目标

props 是父组件向子组件传递数据的唯一官方通道,其核心设计原则是:

  • 单向数据流:父 → 子

  • 子组件不得直接修改 props

  • props 主要用于数据展示和配置,而非业务状态管理

典型使用场景:

  • 表单组件接收初始值

  • 列表组件接收数据源

  • 通用组件接收配置项(如 size、type、disabled)


二、props 的两种定义方式(Vue 3)

1️⃣ 数组形式(不推荐在生产中使用)

export default { props: ['title', 'count'] }

特点:

  • 无类型校验

  • 无默认值

  • 仅适合 demo 或极简组件


2️⃣ 对象形式(推荐)

export default { props: { title: String, count: Number } }

这是最常用、最安全的方式。


三、完整 props 定义(工程级写法)

export default { props: { title: { type: String, required: true }, count: { type: Number, default: 0 }, list: { type: Array, default: () => [] }, user: { type: Object, default: () => ({}) }, status: { type: String, validator(value) { return ['success', 'error', 'warning'].includes(value) } } } }

关键字段说明

字段说明
type类型校验
required是否必传
default默认值
validator自定义校验

四、支持的 type 类型

String Number Boolean Array Object Date Function Symbol

多类型支持

props: { id: [String, Number] }

五、default 的正确写法(高频坑点)

❌ 错误写法(引用类型)

default: [] default: {}

✅ 正确写法

default: () => [] default: () => ({})

原因:

  • 防止多个组件实例共享同一引用对象


六、父组件如何传递 props

1️⃣ 静态传值

<Child title="hello" />

2️⃣ 动态绑定(最常用)

<Child :count="num" />

3️⃣ 对象展开(批量传递)

<Child v-bind="userInfo" />
const userInfo = { name: 'Tom', age: 18 }

七、子组件中使用 props(Vue 3)

1️⃣ Options API

export default { props: { title: String }, mounted() { console.log(this.title) } }

2️⃣ Composition API(推荐)

<script setup> const props = defineProps({ title: String, count: Number }) </script>

也可以解构(注意响应性):

const { title } = defineProps({ title: String })

⚠ 解构后不是响应式(除非使用toRefs

import { toRefs } from 'vue' const props = defineProps({ title: String }) const { title } = toRefs(props)

八、props 是只读的(非常重要)

❌ 错误:直接修改 props

props.count++

Vue 会警告:

Avoid mutating a prop directly


✅ 正确方式 1:使用本地状态

const localCount = ref(props.count)

✅ 正确方式 2:通过事件通知父组件

<Child :count="count" @update="count++" />

九、props 与 v-model(Vue 3 本质)

<Child v-model="value" />

等价于:

<Child :modelValue="value" @update:modelValue="($event)=>(value = $event)" />

子组件:

const props = defineProps({ modelValue: String }) const emit = defineEmits(['update:modelValue']) emit('update:modelValue', newValue)

十、props 的响应式特性

  • 父组件数据变化 → 子组件 props 自动更新

  • props 本身是浅只读响应式

  • 引用类型内部属性可变,但不建议直接改

props.user.name = 'Jack' // 不推荐,破坏数据流

十一、props 常见错误总结

错误说明
修改 props破坏单向数据流
default 使用对象引用共享
解构 props 丢响应式需要 toRefs
props 承担业务状态应使用 state / store
传值与接收命名不一致kebab-case / camelCase

十二、最佳实践建议(非常重要)

  1. props 只负责展示和配置

  2. 复杂交互通过 emit / v-model

  3. 引用类型 default 必须是函数

  4. 对外组件必须写完整 props 校验

  5. 不要在子组件修改父状态


十三、与 Vue 2 的主要区别(简述)

Vue 2Vue 3
setup
defineProps
v-modelvalue + inputmodelValue + update
TS 支持一般非常好
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/19 11:47:50

Linux线程操作全指南

Linux线程概述与操作指南线程与进程对比线程是轻量级进程&#xff0c;属于某个进程&#xff0c;共享进程资源但拥有独立栈区&#xff08;默认8MB&#xff09;。进程资源独立&#xff0c;稳定性更高&#xff1b;线程崩溃可能导致整个进程崩溃。线程创建开销更小&#xff08;仅需…

作者头像 李华
网站建设 2026/2/20 1:41:47

传统VS智能:DBC文件处理效率对比实验

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个DBC文件处理效率对比工具。工具应能&#xff1a;1) 自动生成测试用DBC文件 2) 提供传统手动解析方法 3) 实现AI自动解析方法 4) 记录并对比两种方法的处理时间和准确性。输…

作者头像 李华
网站建设 2026/2/6 22:15:19

LobeChat能否支持生物识别?人脸/声纹/步态特征分析应用

LobeChat能否支持生物识别&#xff1f;人脸/声纹/步态特征分析应用 在智能设备日益渗透日常生活的今天&#xff0c;用户对AI助手的期待早已超越“能聊天”的基础功能。我们希望它认识我、理解我&#xff0c;甚至在我开口之前就知道我想做什么——这种“感知型交互”正成为下一代…

作者头像 李华
网站建设 2026/2/22 4:45:14

Miniconda实现Python多版本灵活切换

Miniconda 实现 Python 多版本灵活切换 在机器学习和科学计算的日常开发中&#xff0c;你是否也曾陷入这样的“环境地狱”&#xff1f;&#x1f631; “这个项目用 PyTorch 1.13&#xff0c;必须 Python 3.9&#xff0c;但我的系统是 3.11。”“同事跑通的代码&#xff0c;我一…

作者头像 李华
网站建设 2026/2/15 13:53:59

场馆预约小程序开发:解锁 “预约经济” 的高效解决方案

在数字化转型加速的背景下&#xff0c;场馆预约需求已渗透体育、办公、教育、文旅等多个领域。传统线下预约模式存在 “信息不透明、操作繁琐、管理低效” 等痛点&#xff0c;而小程序凭借 “轻量化、高触达、易操作” 的优势&#xff0c;成为场馆预约场景的理想载体。本文从核…

作者头像 李华
网站建设 2026/2/22 11:47:12

Product Hunt 每日热榜 | 2025-12-16

1. Unloop 标语&#xff1a;为注意力缺陷多动症&#xff08;ADHD&#xff09;和神经多样性思维者设计的视觉模式映射 介绍&#xff1a;Unloop 是一款可视化的模式映射工具&#xff0c;帮助你识别那些让你感到陷入困境的触发因素、想法、情绪和行为。把这些内容可视化&#xf…

作者头像 李华