广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue单向数据流的深入讲解
  • 626
分享到

vue单向数据流的深入讲解

2024-04-02 19:04:59 626人浏览 独家记忆
摘要

目录Vue单向数据流代码示例特殊情况注意点:总结vue单向数据流 在vue中需要遵循单向数据流原则 在父传子的前提下,父组件的数据发生会通知子组件自动更新子组件内部,不能直接修改父组

vue单向数据流

在vue中需要遵循单向数据流原则

  • 在父传子的前提下,父组件的数据发生会通知子组件自动更新
  • 子组件内部,不能直接修改父组件传递过来的props => props是只读的

代码示例

父组件代码:

<template>
  <div style="border: 1px solid #000">
    <h1>我是父组件</h1>
    <Son :info="info" :person="person"></Son>
    <button @click="fn">修改数据(父)</button>
  </div>
</template>

<script>
import Son from "./Son.vue";
export default {
  data() {
    return {
      info: "我是父组件中的数据",
      person: ["张三", "李四", "赵六"],
    };
  },
  components: {
    Son,
  },
  methods: {
    fn() {
      this.info = "我是父组件中点击修改后的数据";
    },
  },
};
</script>

<style scoped>
</style>

子组件代码:

<template>
  <div>
    <h2>我是子组件</h2>
    <p>{{ info }}</p>
    <p v-for="(item, index) in person" :key="index">{{ item }}</p>
    <button @click="fn">修改数据(子)</button>
  </div>
</template>

<script>
export default {
  props: ["info", "person"],
  methods: {
    fn() {
      // 修改基本数据类型
      this.info = this.info + ",我现在被传递到子组件中";
      // 修改引用数据类型
      // this.person.push("韩七");
    },
  },
};
</script>

<style scoped>
div {
  border: 1px solid red;
  margin: 10px;
}
</style>

当我们在父组件中点击按钮时,会将父组件中的数据进行修改,这样子组件通过props接收的数据也会随之改变,这就印证了vue遵循单向数据流的第一条原则,在父传子的前提下,父组件的数据发生变化会通知子组件自动更新

当我们在子组件中点击按钮时,我们将父组件传递过来的数据进行修改,此时在子组件中数据得到修改,但是会报错,并且,父组件中的数据不会发生改变

然后我们用vue调试工具再来看一下,子组件中的数据发生变化,父组件的数据有没有跟着一起变化

从上面可见知道,父组件的数据发生变化会通知子组件自动更新,但是修改子组件通过props从父组件接收的数据时,它不会通知父组件自动更新,

特殊情况

上面讲述的是将基本数据类型改变会报错,那么将引用数据类型改变会不会报错呢,答案是否定的,如果父组件传给子组件的是一个引用数据类型,这里用数组为例,子组件修改数组内的元素,是不会报错的,数组是引用类型,互相更新,但不能改变引用地址,下面看一下效果

先将子组件内的点击事件处理函数要改变的数据从基本数据类型改为引用数据类型,然后点击按钮来看一下父组件和子组件中的数据有没有同步更新

这样就验证了数据需要遵循单向数据流原则的第二点(特殊情况除外),通过子组件直接修改父组件传递过来的props,这样是非常不建议的,他会影响后续不同状态下数据。

注意点:

在vue中需要遵循单向数据流原则

  1. 在父传子的前提下,父组件的数据发生会通知子组件自动更新
  2. 子组件内部,不能直接修改父组件传递过来的props => props是只读的

最后说明下 : 父组件传给子组件的是一个对象,子组件修改对象的属性,是不会报错的,对象是引用类型, 互相更新;但不能改变引用地址.

总结

到此这篇关于vue单向数据流的文章就介绍到这了,更多相关vue单向数据流内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue单向数据流的深入讲解

本文链接: https://www.lsjlt.com/news/164287.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue单向数据流的深入讲解
    目录vue单向数据流代码示例特殊情况注意点:总结vue单向数据流 在vue中需要遵循单向数据流原则 在父传子的前提下,父组件的数据发生会通知子组件自动更新子组件内部,不能直接修改父组...
    99+
    2022-11-13
  • vue单向数据流的深入理解
    目录官网解释单向数据流是什么示例a-input原始用法组件代码使用场景总结官网解释 所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下...
    99+
    2022-11-13
  • Vue深入讲解数据响应式原理
    目录响应式是什么如何实现数据响应式实现对象属性拦截通用的劫持方案总结响应式是什么 简而言之就是数据变页面变 如何实现数据响应式 在Javascript里实现数据响应式一般有俩种方案,...
    99+
    2022-11-13
  • vue数据流是单向吗
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。vue是单向数据流,数据流向是从上到下,从父组件传递到子组件的。不要和vue的双向数据绑定搞混了;双向数据绑定说的是视图和模板之间的渲染关系,并不是数据的流向关系!vue...
    99+
    2023-05-14
    Vue
  • Shell中重定向的深入讲解
    标准输入、标准输出和标准错误 一个程序的的输入可以来自于键盘,也可以来自于文件或者其他设备;同样的,一个程序也可以将输出显示在屏幕或者保存到文件中。这就涉及到标准输入、标准输出和标准错误。 程序的输入是标准输入,默认是键...
    99+
    2022-06-04
    shell重定向基础 shell输出 重定向 shell重定向怎么使用
  • vue数据流是不是单向的
    本文小编为大家详细介绍“vue数据流是不是单向的”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue数据流是不是单向的”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。是单向的。虽然vue有双向绑定“v-model...
    99+
    2023-07-04
  • R语言的数据输入深入讲解
    既然了解了R语言的基本数据类型,那么如何将庞大的数据送入R语言进行处理呢?送入的数据又是如何在R语言中进行存储的呢?处理这些数据的方法又有那些呢?下面我们一起来探讨一下。 首先,数据...
    99+
    2022-11-11
  • Kotlin数据容器深入讲解
    目录前言一、Kotlin数组1、Kotlin数组创建技巧2、原生类型数组3、数组常见的操作二、Kotlin集合1、集合创建的技巧2、集合的操作前言 容器是用于存放数据的载体。容器分为...
    99+
    2022-11-13
  • vue指的是单项数据流还是双向数据流
    这篇文章给大家分享的是有关vue指的是单项数据流还是双向数据流的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 vue是单项数据流。虽然vue有双向绑定...
    99+
    2022-10-19
  • 深入了解Vue中双向数据绑定原理
    目录数据的变化反应到视图命令式操作视图声明式操作视图小结视图的变化反应到数据现存的问题数据的变化反应到视图 前面我们了解到数据劫持之后,我们可以在数据发生修改之后做任何我们想要做的事...
    99+
    2022-11-13
  • vue响应式原理与双向数据的深入解析
    了解object.defineProperty 实现响应式 清楚 observe/watcher/dep 具体指的是什么 了解 发布订阅模式 以及其解决的具体问题 在Javascri...
    99+
    2022-11-12
  • Java中控制流程语句的深入讲解
    目录前言 if-then if-then-else switch 使用 String while do-while for break continue return 总结前言 流...
    99+
    2022-11-12
  • python中pandas.read_csv()函数的深入讲解
    这里将更新最新的最全面的read_csv()函数功能以及参数介绍,参考资料来源于官网。 pandas库简介 官方网站里详细说明了pandas库的安装以及使用方法,在这里获取最新的p...
    99+
    2022-11-12
  • java数据类型和运算符的深入讲解
    一.整型变量 1.基本格式 int 变量名 = 初始值; 代码示例: public class CSDN { public static void main(String[]...
    99+
    2022-11-11
  • Vue中插槽和过滤器的深入讲解
    目录插槽什么是插槽?插槽内容编译作用域后备内容具名插槽过滤器概念语法全局过滤器局部过滤器练习总结插槽 什么是插槽? 概念 Vue 实现了一套内容分发的 API,为组件提供了一个 ...
    99+
    2022-11-12
  • 浅谈Vue的双向绑定和单向数据流冲突吗
    目录前言单向绑定 vs 双向绑定单向数据流 vs 双向数据流为什么说v-model只是语法糖总结参考资料前言 众所周知,Vue中更加推荐单向数据流的状态管理模式(比如Vuex),但V...
    99+
    2022-11-13
  • Vue的双向绑定和单向数据流有没有冲突
    这篇“Vue的双向绑定和单向数据流有没有冲突”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue的双向绑定和单向数据流有没有...
    99+
    2023-06-29
  • 深入理解Vue的数据响应式
    目录1. ES语法的getter和setter2. ES语法的 defineProperty3. Vue对数据的代理和监听4. Vue的数据响应式1. ES语法的getter和set...
    99+
    2022-11-12
  • Vue数据双向绑定的实现方式讲解
    目录前言一、input和textarea二、radio和CheckBox三、select四、双向绑定的修饰符前言 在web开发应用中,很多项目都会用到表格一列的组件进行数据的传输、获...
    99+
    2022-11-13
  • Vue数据代理的实现流程逐步讲解
    目录一,前言二,数据代理的实现1,Vue 是如何操作数据的2,当前是如何操作数据的3,数据代理的思路4,数据代理的实现5,数据代理的测试三,结尾一,前言 上篇,主要介绍了 Vue 数...
    99+
    2023-01-06
    Vue数据代理 Vue数据代理原理 vue数据代理怎么实现的
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作