vue实现公共组件传值并及时监听到数据更新视图

 更新时间:2023年01月13日 15:12:24   作者:小羊羊.  
这篇文章主要介绍了vue实现公共组件传值并及时监听到数据更新视图方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue公共组件传值及时监听到数据更新视图

场景

AB两个子组件在 父页面中,(我们险别估损信息为A,立案信息为B)

B组件的某个值是和A组件中一样的且A组件值变化B即使监听并渲染.例如:下图总额A组件要把金额传给  B组件的估损金额框,A金额变B也变

金额已经绑定在A组件中

用兄弟传值 把A组件的金额传到B组件的估损金额

1.兄弟组件的语法是。先建一个bus.js文件

import Vue from 'vue'
export default new Vue()

2.在A组件中引入bus.JS

3.把本地的 金额 值传给B组件,我这里是下拉框值变化的时候会触发。

 

4.为了初始化页面时就及时更新,在created在调用这个方法

5.B组件引入bus.js文件,并在页面初始化时候接受A组件传给的金额值。(我这里用本地的price值去接受传过来的)

6.这时已经接到A组件传过来的值了,在监听这个值如果有变化及时把最新的值赋给本地变量

vue组件传值的几种方式

父传子

当子组件在父组件中当做标签使用的时候,给子组件定义一个自定义属性,值为想要传递的数据。

在子组件中通过props进行接收,props是专门用来接收外边的的数据的,有两种接收方式,数组和对象,对象可以限制数据的类型。

在这里简单介绍一下单项数据流的概念。

单向数据流:父组件向子组件传递数据的时候,子组件不允许更改父组件的数据,因为父组件会向多个子组件传值,如果说某个子组件对父组件的数据进行修改的话,很有可能会导致其他的组件发生错误,很难对数据的错误进行捕捉。

子传父

当子组件在父组件中当做标签使用的时候,如果子组件需要给父组件传递数据的时候,需要在子组件中定义一个自定义的事件,事件名称不需要加()的

在子组件中通过this.$emit触发自定义事件,将需要传递的参数通过emit的第二个参数进行传递

非父子组件传值

1.通过创建一个公共的Vue实例对象,this的指向是不同的,所以不能互相传值,所以创建一个公共的实例,就可以传值了,将实例对象绑定在Vue的原型身上即可。传值的一方调用$emit,接收的一方调用$on,但是这种方法非常耗费性能,我们可以将on,emit等棱出来挂载。

2.用第三方封装好的eventbus

3自己封装的$on,$emit,$off等方法。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue计算属性与监视(侦听)属性的使用深度学习

    Vue计算属性与监视(侦听)属性的使用深度学习

    这篇文章主要介绍了Vue计算属性与监视(侦听)属性的使用,计算属性指的是通过一系列运算之后,最终得到一个值,watch监视(侦听)器允许开发者监视数据的变化,从而针对数据的变化做特定的操作,本文就这两种属性给大家详细讲解,感兴趣的朋友一起学习吧
    2022-11-11
  • vue的一个分页组件的示例代码

    vue的一个分页组件的示例代码

    本篇文章主要介绍了vue的一个分页组件的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • Vue使用vue-cli创建项目

    Vue使用vue-cli创建项目

    这篇文章主要介绍了Vue使用vue-cli创建项目,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • vue.js给动态绑定的radio列表做批量编辑的方法

    vue.js给动态绑定的radio列表做批量编辑的方法

    下面小编就为大家分享一篇vue.js给动态绑定的radio列表做批量编辑的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • Vue项目打包部署后浏览器自动清除缓存问题的解决方法

    Vue项目打包部署后浏览器自动清除缓存问题的解决方法

    这篇文章主要介绍了vue打包部署后 浏览器缓存问题,导致控制台报错ChunkLoadError: Loading chunk failed的解决方案,文中有相关的图文和代码供大家参考,具有一定的参考价值,需要的朋友可以参考下
    2024-12-12
  • vue实现密码显示与隐藏按钮的自定义组件功能

    vue实现密码显示与隐藏按钮的自定义组件功能

    本文通过两种思路给大家介绍vue实现密码显示与隐藏按钮的自定义组件功能,感兴趣的朋友跟随小编一起看看吧
    2019-04-04
  • VUE使用canvas实现签名组件

    VUE使用canvas实现签名组件

    这篇文章主要为大家详细介绍了VUE使用canvas实现签名组件,兼容PC移动端,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • vue fetch中的.then()的正确使用方法

    vue fetch中的.then()的正确使用方法

    这篇文章主要介绍了vue fetch中的.then()的正确使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • 详解vuex 中的 state 在组件中如何监听

    详解vuex 中的 state 在组件中如何监听

    本篇文章主要介绍了详解vuex 中的 state 在组件中如何监听,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Vue中的Object.defineProperty全面理解

    Vue中的Object.defineProperty全面理解

    这篇文章主要介绍了Vue中的Object.defineProperty全面理解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04

最新评论