vue3中修改vuex中state中的数据

vue3中修改vuex中state中的数据

1.直接通过store.state修改

如 :

	//vuex文件
import { createStore } from 'vuex'
export default createStore({
  state: {
    fullscreenLoading: false // 全屏加载
  },
  getters: {
  },
  mutations: {
  },
  actions: {
  },
  modules: {
  }
})
// 组件
import { useStore } from 'vuex'
export default {
	setup() {
		// vuex
    	const store = useStore()
    	//直接修改
    	store.state.fullscreenLoading = true
	}
}

但是并不推荐直接修改的方式
因为state是实时更新的,直接修改是能够异步操作的,当执行了异步操作,会导致其他使用state数据的程序出现问题,所以我们开发过程中更倾向于使用mutations加commit方式进行state数据的改变,通过mutations限制了异步操作

2.使用commit触发Mutations操作修改

	//vuex文件
import { createStore } from 'vuex'

export default createStore({
  state: {
    fullscreenLoading: false // 全屏加载
  },
  getters: {
  },
  mutations: {
    updateFullLoading(state, status){
      state.fullscreenLoading = status
    }
  },
  actions: {
  },
  modules: {
  }
})
// 组件
import { useStore } from 'vuex'
export default {
	setup() {
		// vuex
    	const store = useStore()
    	// mutaions修改
    	store.commit('updateFullLoading', true)
	}
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue3Vuex是一个用于集管理应用程序状态的库。通过使用Vuex,我们可以在组件之间共享和管理数据,以及响应数据的变化。引用提到了关于在Vue使用Vuex的详细介绍和应用。在Vue3,我们可以通过创建一个store实例来使用Vuex。在`src/store/index.js`,可以按需引入`createStore`函数并使用它来创建一个store实例。这个store实例包含了state、mutations、actions、getters和modules等。其state用于存储应用程序的数据状态,mutations是用于修改state的方法,actions是用于触发mutations的方法,getters是用于获取state的计算属性,modules是用于模块化组织state、mutations、actions和getters等。 通过使用Vuex,我们可以实现组件间的交互和数据共享。比如在引用提到的例子,可以通过Ajax从云端动态获取用户的动态页面,实现了用户动态的展示和更新。 总结来说,在Vue3Vuex是一个用于集管理应用程序状态的库,可以通过创建一个store实例来使用它,并且可以实现组件间的数据共享和交互。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue3 学习——vue使用vuex(超详细)](https://blog.csdn.net/qq_46201146/article/details/125805058)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Vue3vuex的基本使用](https://blog.csdn.net/m0_67394360/article/details/123370486)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牛仔不当马仔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值