返回顶部
首页 > 资讯 > 前端开发 > JavaScript >关于vuex更新视图引发的一些思考详析
  • 187
分享到

关于vuex更新视图引发的一些思考详析

2024-04-02 19:04:59 187人浏览 泡泡鱼
摘要

目录场景解决总结扩展Vuex可以集中式存储管理应用的所有组件的状态,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高

Vuex可以集中式存储管理应用的所有组件的状态,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新

但是,最近踩了vuex的坑:

场景

  • 第一次进入页面加载数据,数据不显示,点击某个按钮或者切换页面后,数据会展示出来
  • 通过分析发现,当第一次加载页面的时候,获取数据的数据为{} (空对象),当数据获取完毕,执行commit()
  • 而此时通过commit()已经改变了state中的数据,在页面中通过computed也可以获取更新后的数据。但是视图没有更新,获取的数据没有展示出来

解决

  • 尝试在页面中发送commit()来再次更新视图,无效

  • 将Vue.set(state, 'myData', data),无效

  • ......

最终方案:

代码中所声明的对象里面的key是动态的,所以初始只声明了{ }。

原来,数据是数组的时候,不能通过索引直接进行赋值,也不能修改数组的长度。 而Vuex只会跟踪在对象创建时就存在的属性,新添加到对象上的新属性不会触发更新。

并且循环嵌套层级太深,视图也可能不更新

最终,给数组对象赋值,这里转化了一下写法,生效。具体如下:

const store = new Vuex.Store({
  state: {
    myData: []
  },
  mutations: {
    setData(state, data) {
      // state.myData = data  不更新视图
      Vue.set(state, 'myData', JSON.parse(jsON.stringify(data)))
    }
  },
  actions: {
    myFn () {
      store.commit('setData')
    }
  }
})

export default store

如果添加了新的对象属性,也可以使用Object.assign(),但必须深拷贝(否则加到对象上的新属性不会触发更新)

let someObject = Object.assign({}, someObject, {newField: value}) // 深拷贝
// Object.assign(this.someObject, { key: 1 }) // 浅拷贝

总结

  • 不能直接去改变 store 中的状态。改变 store 中的状态的需要提交 (commit) mutation
  • 在组件中调用 store 中的状态在计算属性中返回即可获取,也可以直接$store.state来获取
computed: {
    myData () {
      return store.state.myData
    }
},
mounted() {
    console.log(this.store.state.myData)
}
  • 为数组添加新属性并不会触发视图更新,因为vue没有给新属性增加get和set监听

  • 赋值的数据,如果循环嵌套层级太深,可能会导致视图不更新

扩展

这些方法操作数组,vue可以检测到数据变化:

push()
pop()
shift()
unshift()
splice()
sort()
reverse()

而下面这些不会改变原数组(返回了新数组),vue检测不到:

filter()
concat()
slice()

到此这篇关于vuex更新视图引发的一些思考的文章就介绍到这了,更多相关vuex更新视图内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 关于vuex更新视图引发的一些思考详析

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

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

猜你喜欢
  • 关于vuex更新视图引发的一些思考详析
    目录场景解决总结扩展vuex可以集中式存储管理应用的所有组件的状态,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高...
    99+
    2024-04-02
  • vuex更新视图引发的问题怎么解决
    本篇内容主要讲解“vuex更新视图引发的问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vuex更新视图引发的问题怎么解决”吧!场景第一次进入页面加载数据,数据不显示,点击某个按钮或者...
    99+
    2023-07-02
  • Android开发中关于获取当前Activity的一些思考
    在Android开发过程中,我们有时候需要获取当前的Activity实例,比如弹出Dialog操作,必须要用到这个。关于如何实现由很多种思路,这其中有的简单,有的复杂,这里简单...
    99+
    2022-06-06
    activity android开发 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作