广告
返回顶部
首页 > 资讯 > 精选 >Vue怎么实现响应式数据更新
  • 673
分享到

Vue怎么实现响应式数据更新

2023-07-04 15:07:39 673人浏览 独家记忆
摘要

本文小编为大家详细介绍“Vue怎么实现响应式数据更新”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue怎么实现响应式数据更新”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。首先假设我们在祖辈时候传入进来是个动态

本文小编为大家详细介绍“Vue怎么实现响应式数据更新”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue怎么实现响应式数据更新”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

首先假设我们在祖辈时候传入进来是个动态的数据,官方不是说如果你传入了一个可监听的对象,那么其对象还是可响应的么?

parent父页面:

export default { provide() {  return  { foo: this.fonnB } }, data(){  return { fonnB: 'old Word '}  }created() {  setTimeout(()=>{   this.fonnB = 'new words';  // 这里仅仅foonB变化了,foo没有变化   this._provided.foo="new words"; // 这里foo变化了,但子组件获得的foo 依旧是old words   console.log( this._provided);  },1000) },}

child子页面:

export default { inject:['foo'], data(){  return { chilrfoo: this.foo }  }, created() {  setTimeout(()=>{   // 子组件获得的foo 依旧是old words   console.log( this.foo)  },2000) }}

结果:

通过上面方式,经过验证,子组件页面都没办法实现响应更新this.foo的值。可能我们对官方理解还是有误,下面通过网上资料和自己构思实现了响应式数据更新

示例(结果仍不可行)

很明显上面再父组件定时器内我们是改变了数据源,这个时候我们就在想,我们改变的数据到底有没有传入到子孙组件中,那么要验证这个问题,我们不妨可以在子孙组件中手动写set 函数,computed 本身就只相当于一个get函数,当然,你也可以试试watch

parent父页面:

export default {provide() {   return  { foo: this.fonnB }  },  data(){   return {    fonnB: 'old word'   }   }   created() {   setTimeout(()=>{    this.fonnB = "new words";      // 这里foo变化了,但子组件获得的foo 依旧是old words   },1000)  }, }

child子页面:

export default {  inject:['foo'],  data(){   return {    childfooOld: this.foo   }   },  computed:{    chilrdfoo() {      return this.foo    }  }, created () {    console.log(this.foo)    // -> 'old word'    setTimeout(() => {      console.log(this.chilrdfoo); // 这里计算属性依旧是old words    }, 2000);   } }

通过computed,我们都知道data中有get/set,数据也是响应式的,但为什么没更新,有点疑惑,如果有大佬知道能解释清楚的可以探讨。

但是,但是,但是!实际需求肯定没有这么简单,往往我们需要的是共享父组件里面的动态数据,这些数据可能来自于data 或者 store。 就是说父组件里面的数据发生变化之后,需要同步到子孙组件里面。这时候该怎么做呢?
我想的是将一个函数赋值给provide的一个值,这个函数返回父组件的动态数据,然后在子孙组件里面调用这个函数。
实际上这个函数存储了父组件实例的引用,所以每次子组件都能获取到最新的数据。代码长下面的样子:

Parent组件:

<template>  <div class="parent-container">   Parent组件   <br/>   <button type="button" @click="changeName">改变name</button>   <br/>   Parent组件中 name的值: {{name}}   <Child v-bind="{name: 'k3vvvv'}" />  </div></template><style scoped> .parent-container {  padding: 30px;  border: 1px solid burlywood; }</style><script>import Child from './Child'export default { name: 'Parent', data () {  return {   name: 'Kevin'  } }, methods: {  changeName (val) {   this.name = 'Kev'  } }, provide: function () {  return {   nameFromParent: this.name,   getReaciveNameFromParent: () => this.name  } }, // provide: { // nameFromParent: this.name, // getReaciveNameFromParent: () => this.name // }, components: {  Child }}</script>

Child组件

<template> <div class="child-container">  Child组件  <br/>  <GrandSon /> </div></template><style scoped> .child-container {  padding: 30px;  border: 1px solid burlywood; }</style><script>import GrandSon from './GrandSon'export default { components: {  GrandSon }}</script>

GrandSon组件:

<template> <div class="grandson-container">  Grandson组件  <br/>  {{nameFromParent}}  <br/>  {{ReactiveNameFromParent}} </div></template><style scoped> .grandson-container {  padding: 30px;  border: 1px solid burlywood; }</style><script>export default { inject: ['nameFromParent', 'getReaciveNameFromParent'], computed: {  reactiveNameFromParent () {   return this.getReaciveNameFromParent()  } }, watch: {  'reactiveNameFromParent': function (val) {   console.log('来自Parent组件的name值发生了变化', val)  } }, mounted () {  console.log(this.nameFromParent, 'nameFromParent') }}</script>

为什么要使用Vue

Vue是一款友好的、多用途且高性能的javascript框架,使用vue可以创建可维护性和可测试性更强的代码库,Vue允许可以将一个网页分割成可复用的组件,每个组件都包含属于自己的htmlCSS、JavaScript,以用来渲染网页中相应的地方,所以越来越多的前端开发者使用vue。

读到这里,这篇“Vue怎么实现响应式数据更新”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: Vue怎么实现响应式数据更新

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

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

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

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

下载Word文档
猜你喜欢
  • Vue怎么实现响应式数据更新
    本文小编为大家详细介绍“Vue怎么实现响应式数据更新”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue怎么实现响应式数据更新”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。首先假设我们在祖辈时候传入进来是个动态...
    99+
    2023-07-04
  • vue怎么实现响应式与双向数据
    这篇文章给大家介绍vue怎么实现响应式与双向数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。vue-响应式是什么Vue 最独特的特性之一,是其非侵入性的响应式系统。数据模型仅仅是普通的 JavaScript对象。而当...
    99+
    2023-06-15
  • 怎么实现Vue的响应式
    这篇文章主要介绍了怎么实现Vue的响应式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简易版 以watch为切入点watch是平时开发中使用...
    99+
    2022-10-19
  • vue+element怎么实现响应式
    本篇内容介绍了“vue+element怎么实现响应式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、如何使用Element UI在Vue项...
    99+
    2023-07-05
  • vue+echarts实现数据实时更新
    本文实例为大家分享了vue+echarts实现数据实时更新的具体代码,供大家参考,具体内容如下 今天在管理后台新增一个图表,用了echarts,记录一下 根据数据实时更新 安装 np...
    99+
    2022-11-13
  • Vue中数据响应式是什么
    这篇文章将为大家详细讲解有关Vue中数据响应式是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. ES语法的getter和setter在开始了解 Vue 的数据响应式原理前应该先搞清楚 ES语法 中...
    99+
    2023-06-15
  • vue中数据更新视图不更新怎么解决
    本文小编为大家详细介绍“vue中数据更新视图不更新怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue中数据更新视图不更新怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。vue数据更新视图不更新d...
    99+
    2023-07-02
  • Vue源码学习defineProperty响应式数据原理实现
    目录准备工作第一步 对对象进行劫持第二步 修改取值方法第三步 深度属性劫持准备工作 接上文数据初始化完成之后,就可以对数据进行劫持。Vue2中对数据进行劫持采用了一个Api叫Obje...
    99+
    2022-11-13
  • Vue数据响应式原理是什么
    本文小编为大家详细介绍“Vue数据响应式原理是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue数据响应式原理是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。响应式是什么简而言之就是数据变页面变如何实...
    99+
    2023-06-30
  • jquery php怎么实现实时数据更新
    本篇文章给大家分享的是有关jquery php怎么实现实时数据更新,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。本文操作环境:Windows7系统、PHP7.1版、Dell G...
    99+
    2023-06-22
  • vue增加数据不更新怎么办
    本教程操作环境:Windows10系统、Vue 3版、Dell G3电脑。vue增加数据不更新怎么办?解决vue数据不实时更新的问题(数据更改了,但数据不实时更新)一、在我们使用vue进行开发的过程中,可能会遇到一种情况:当生成vue实例后...
    99+
    2023-05-14
    Vue
  • Vue.js响应式数据如何实现
    小编给大家分享一下Vue.js响应式数据如何实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基本概念副作用函数什么是副作用函数?意如其名,副作用函数指的就是会产...
    99+
    2023-06-29
  • c# winform动态更新数据怎么实现
    在C# WinForms中实现动态更新数据,可以使用数据绑定和事件处理来实现。 使用数据绑定 创建一个数据源,例如一个List或D...
    99+
    2023-10-26
    c# winform
  • Vue对象和数据怎么强制更新
    本文小编为大家详细介绍“Vue对象和数据怎么强制更新”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue对象和数据怎么强制更新”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。对象和数据的强制更新数组更新以下支持自...
    99+
    2023-06-29
  • Vue数据响应式原理实例代码分析
    本文小编为大家详细介绍“Vue数据响应式原理实例代码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue数据响应式原理实例代码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。改造数据我们先来尝试写一个函数...
    99+
    2023-07-04
  • Vue 中数据响应式的原理是什么
    Vue 中数据响应式的原理是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。改造数据我们先来尝试写一个函数,用于改造对象:为什么要先写这个函...
    99+
    2022-10-19
  • SQLServer2005数据库中怎么实现批量更新
    这篇文章将为大家详细讲解有关SQLServer2005数据库中怎么实现批量更新,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  SQLServer2005数...
    99+
    2022-10-18
  • vue长列表数据刷新怎么实现
    本篇内容介绍了“vue长列表数据刷新怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、效果展示两列均为局部可视范围内数据刷新二、代码...
    99+
    2023-07-05
  • 使用javascript怎么实现页面无刷新更新数据
    这篇文章给大家介绍使用javascript怎么实现页面无刷新更新数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 首先在服务器上建立一个CheckUser.asp文件,用来检测用户是否存在,根据用户是否存在...
    99+
    2023-06-10
  • Vue中怎么通过AJAX动态更新数据
    本文小编为大家详细介绍“Vue中怎么通过AJAX动态更新数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue中怎么通过AJAX动态更新数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。代码如下:var&nb...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作