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
}

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

相关推荐
问心无愧051318 小时前
ctf show web入门160 161
前端·笔记
李小白6619 小时前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
humcomm19 小时前
AI编程时代新前端职位
前端·ai编程
好家伙VCC19 小时前
Web Components主题热切换方案揭秘
java·前端
甲维斯20 小时前
Kimi版超级玛丽效果“惊人”,配额不足5厘米!
前端·人工智能
hboot20 小时前
AI工程师第一课 - Python
前端·后端·python
凉菜凉凉20 小时前
AI时代,被抛弃的前端
前端·ai
console.log('npc')20 小时前
AI前端工程与生成式UI学习路线
前端·人工智能·ui
huangdong_21 小时前
淘宝商品SKU图自动分类技术深度解析:从DOM解析到智能归档
开发语言·javascript·ecmascript
梦曦i21 小时前
uni-router v1.1.1发布:守卫超时保护+路由监听
前端·uni-app