VUE组件配置项(二)data和props

在 Vue(尤其是 Vue 2 / Options API)里,propsdata 都是组件中的数据来源,但职责完全不同。可以理解为:

  • props:外部传进来的数据(输入)
  • data:组件自己维护的数据(内部状态)
对比项 props data
数据来源 父组件传入 组件自己定义
所有权 父组件 当前组件
是否可直接修改 不建议(只读) 可以
用途 输入参数 内部状态
更新方向 父 → 子 本组件内部

一、props

1. props:父组件传给子组件的数据

props组件之间通信 的方式,通常是 父 → 子

父组件

复制代码
<template>
  <UserCard :name="userName" />
</template>

<script>
export default {
  data() {
    return {
      userName: "Tom"
    }
  }
}
</script>

子组件

复制代码
<script>
export default {
  props: {
    name: String
  }
}
</script>

<template>
  <div>{{ name }}</div>
</template>

这里:

  • userName 在父组件里
  • 通过 props 传给子组件
  • 子组件通过 name 接收

特点

① 由父组件控制

父组件改了,子组件自动更新。

复制代码
this.userName = "Jerry"

子组件里的 name 也会变。


② 单向数据流(one-way data flow)

子组件不要直接修改 props。

错误写法:

复制代码
this.name = "abc"

Vue 会警告:

Avoid mutating a prop directly

因为:

  • 数据所有权在父组件
  • 父组件一刷新,值会覆盖回来

如果要改,一般复制一份到 data

复制代码
props: ['name'],

data() {
  return {
    localName: this.name
  }
}

然后修改:

复制代码
this.localName = "new value"

二、data:组件自己的内部状态

data 是组件自己管理的数据。

例如:

复制代码
复制代码
<script>
export default {
  data() {
    return {
      count: 0
    }
  }
}
</script>

<template>
  <button @click="count++">
    {{ count }}
  </button>
</template>

这里:

  • count 不来自父组件
  • 是组件内部状态
  • 组件自己维护

特点

① 可修改
复制代码
复制代码
this.count++

没问题。


② 每个组件实例独立

Vue 要求 data 必须是函数:

复制代码
复制代码
data() {
  return {
    count: 0
  }
}

不能:

复制代码
复制代码
data: {
  count: 0
}

因为多个组件实例会共享同一个对象,导致数据串了。

相关推荐
Martin -Tang1 小时前
uniapp+vue3+ts自定义表格
javascript·vue.js·uni-app
问心无愧05131 小时前
ctf show web入门 89
android·前端·笔记
hexu_blog1 小时前
前端vue后端java+springboot如何显示视频压缩
前端·vue.js·vue压缩视频·java压缩视频·指定大小压缩视频
欧阳天风1 小时前
electron播放本地音乐的问题
前端·javascript·electron
艾伦野鸽ggg2 小时前
CSS布局与动效知识梳理
前端·css
介一安全2 小时前
【漏洞学习】聊天机器人安全漏洞实战:服务器端JavaScript注入探秘
javascript·安全性测试·聊天机器人
ljt27249606612 小时前
Vue笔记(二)--组件的属性和方法
前端·vue.js·笔记
Boop_wu2 小时前
[前端] CSS 常用样式(聊天界面 / 网页布局专用)
前端·css·css3
声声codeGrandMaster2 小时前
React框架的基础代码使用
前端·react.js·前端框架