第二阶段: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(简写:)动态绑定数据
相关推荐
灵感__idea3 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea4 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd6 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌6 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈6 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫7 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝7 小时前
svg图片
前端·css·学习·html·css3
橘子编程7 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇7 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧7 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint