第二阶段:Vue 组件化开发(第 18天)

Vue组件间通信:父组件向子组件传值(props)

一、核心概念
  1. props的作用

    父组件通过props向子组件传递数据,实现数据由上至下的流动。

  2. props的定义

    子组件需在props选项中声明接收的属性:

    javascript 复制代码
    // 子组件 ChildComponent.vue
    export default {
      props: ['message'] // 简单声明
    }
  3. 类型与默认值

    支持类型校验和默认值设置:

    javascript 复制代码
    props: {
      count: {
        type: Number,    // 指定为数字类型
        default: 0       // 默认值
      },
      items: {
        type: Array,
        required: true  // 必须传递
      }
    }

二、案例演示
父组件(传递数据)
vue 复制代码
<template>
  <ChildComponent 
    :message="parentMsg" 
    :count="num" 
    :items="list"
  />
</template>

<script>
export default {
  data() {
    return {
      parentMsg: "来自父组件的数据",
      num: 42,
      list: ["A", "B", "C"]
    }
  }
}
</script>
子组件(接收与渲染)
vue 复制代码
<template>
  <div>
    <p>{{ message }}</p> <!-- 输出:来自父组件的数据 -->
    <p>计数:{{ count }}</p> <!-- 输出:42 -->
    <ul>
      <li v-for="item in items" :key="item">{{ item }}</li>
    </ul>
  </div>
</template>

<script>
export default {
  props: {
    message: String,
    count: {
      type: Number,
      default: 100
    },
    items: {
      type: Array,
      required: true
    }
  }
}
</script>

三、单向数据流原则
  1. 直接修改props的报错

    若在子组件中尝试修改count

    javascript 复制代码
    this.count = 100; // 错误操作!

    控制台将报错:

    复制代码
    Avoid mutating a prop directly...
  2. 正确解决方案

    • 子组件通过$emit事件通知父组件修改数据
    javascript 复制代码
    this.$emit('update-count', newValue);
    • 父组件监听事件并更新:
    vue 复制代码
    <ChildComponent @update-count="num = $event" />

四、总结要点
关键点 说明
声明式接收 子组件通过props选项显式声明接收的属性
类型校验 支持String/Number/Boolean/Array/Object等类型校验
默认值与必传 default设置默认值,required: true强制必须传递
单向数据流 子组件不可直接修改props,需通过事件通知父组件
动态传递 父组件使用v-bind(简写:)动态绑定数据
相关推荐
烟花落o3 分钟前
贪吃蛇及相关知识点讲解
c语言·前端·游戏开发·贪吃蛇·编程学习
kgduu3 分钟前
js之javascript API
javascript
晚霞的不甘7 分钟前
Flutter for OpenHarmony专注与习惯的完美融合: 打造你的高效生活助手
前端·数据库·经验分享·flutter·前端框架·生活
BYSJMG13 分钟前
计算机毕设选题推荐:基于大数据的癌症数据分析与可视化系统
大数据·vue.js·python·数据挖掘·数据分析·课程设计
kogorou0105-bit17 分钟前
前端设计模式:发布订阅与依赖倒置的解耦之道
前端·设计模式·面试·状态模式
止观止34 分钟前
像三元表达式一样写类型?深入理解 TS 条件类型与 `infer` 推断
前端·typescript
xiaoqi9221 小时前
React Native鸿蒙跨平台实现图片画廊类页面是视觉展示型APP(如摄影类、图库类、设计类APP)的核心载体,其核心需求是实现图片的流畅渲染
javascript·react native·react.js·ecmascript·harmonyos
chenhdowue1 小时前
vue3甘特图 vxe-gantt 行内显示子任务,拆分任务展示同时可拖拽调整任务日期
vue.js·甘特图·vxe-gantt
雪芽蓝域zzs1 小时前
uniapp 省市区三级联动
前端·javascript·uni-app
Highcharts.js1 小时前
Next.js 集成 Highcharts 官网文档说明(2025 新版)
开发语言·前端·javascript·react.js·开发文档·next.js·highcharts