第二阶段: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(简写:)动态绑定数据
相关推荐
原则猫1 小时前
前端基础大厦
前端
陈随易3 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart3 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒5 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰6 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马6 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8186 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花7 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12277 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪8 小时前
Vue3-生命周期
前端