温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

vuex如何提交state&&实时监听state数据的改变

发布时间:2021-07-28 09:21:46 来源:亿速云 阅读:240 作者:小新 栏目:web开发

这篇文章主要为大家展示了“vuex如何提交state&&实时监听state数据的改变”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vuex如何提交state&&实时监听state数据的改变”这篇文章吧。

项目背景

websocket长连接 根据指示进行四个页面之间的跳转,在各页面执行相应的逻辑处理。

项目搭建结构如下所示:

vuex如何提交state&&实时监听state数据的改变

解决方案

在四个页面外面写个父页面,router路径如下所示:

vuex如何提交state&&实时监听state数据的改变

vuex

\src\store\mutations.js

//存储到vuex里面

[WEBSOCKETDATA](state,socketdata){  state.socketData=null;//vue监听不到数组的改变 所以清空重置一下就好咯  state.socketData=socketdata  }

\src\store\getters.js

export default {  getterSocketData (state) {  return state.socketData  } }

\src\store\index.js

import Vue from 'vue' import Vuex from 'vuex' import mutations from './mutations' import getters from './getters'

Vue.use(Vuex)

const state = {  socketData:{},//websocket数据 } export default new Vuex.Store({  state,  mutations,  getters })

\src\components\index.vue

父页面

import {mapMutations,mapState} from 'vuex' export default {  computed:{    ...mapState([    'socketData',    ])   },  data(){   return{   skip:'2',   webdata:{    "current_item": "111", "show_item": 'false', "cart_item_list": [],"totalPrice":7.5,"delIndexList":[],'addList':[]   },   }  },  mounted(){   // this.initWebsocket()   var addList=[{"sku":"1","num":"2","price":3.5,"name":'苹果0'}];   var delIndexList=[];   this.webdata.addList=addList;   this.webdata.delIndexList=delIndexList;   this.websocket_data(this.webdata)   console.log("index1--------------------")   console.log(this.socketData);   setTimeout(()=>{//定时器为了模拟websocket发送数据   var addList=[{"sku":"1","num":"2","price":3.5,"name":'苹果11'}];   var delIndexList=[0];   this.webdata.addList=addList;   this.webdata.delIndexList=delIndexList;   this.$store.commit("websocket_data",this.webdata)//必须写 要不然getter拿不到改变之后的数据   console.log("index--------------------");   console.log(this.socketData);   },1000);  },  }

src\components\shoppingCart.vue

子页面 根据websocket传来的数据进行逻辑操作

import {mapState,mapMutations,mapGetters} from 'vuex'; export default {  data(){   return{   prolength:0,   defaultImg: 'this.src="' + require('../assets/defaultImg.png') + '"',   productinfos: {    "current_item": "111", "show_item": 'false', "cart_item_list": [],"totalPrice":7.5,"delIndexList":[],'addList':[]   },   MyMar:'',   }  },  computed: {//监听socketData的变化 做页面处理   ...mapState([   'socketData',   ]),   ...mapGetters([   'getterSocketData',   ])  },   watch:{   getterSocketData(message){//message 就是socketData   console.log(message);//根据数据指示 进行逻辑操作   ........................   }   } }

以上是“vuex如何提交state&&实时监听state数据的改变”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI