目录场景解决总结扩展Vuex可以集中式存储管理应用的所有组件的状态,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高
Vuex可以集中式存储管理应用的所有组件的状态,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新
但是,最近踩了vuex的坑:
尝试在页面中发送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 }) // 浅拷贝
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
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0