第二阶段: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(简写:)动态绑定数据
相关推荐
WooaiJava1 小时前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
LYFlied1 小时前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a1 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
Never_Satisfied1 小时前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌411 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
B站_计算机毕业设计之家2 小时前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
WeiXiao_Hyy2 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
吃杠碰小鸡2 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone3 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09013 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js