我是默,一个在CSDN分享笔记的博主。
在这里,我要推荐给大家我的专栏《Vue》。
无论你是编程小白,还是有一定基础的程序员,这个专栏都能满足你的需求。我会用最简单易懂的语言,带你走进Vue的世界,让你从零开始,一步步成为JAVA大师。
让我们在Vue的世界里畅游吧!
如果感觉还不错的话请记得给我点赞哦!
期待你的加入,一起学习,一起进步!
Vuex是一个专为Vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态的一致性。Vuex能够帮助我们更好地组织和管理Vue.js应用中的状态。
在Vue.js中,组件之间的通信可以通过props和events来实现,但是当应用较大且组件较多时,这种方式会变得复杂和冗余。Vuex提供了一个全局的状态管理机制,将应用中的状态存储在一个单一的、可预测的状态树中(即store),并可以在任何组件中访问和修改这些状态。
Vuex的核心概念包括:state(存储应用的状态)、mutations(修改状态的方法)、actions(处理异步操作)、getters(获取派生状态)。通过定义这些概念,我们可以清晰地管理应用的状态和数据流动。
npm install vuex -S
<div>
<h1>第一个界面h1>
{{msg}}
div>
<script>
export default{
data() {
return{
msg:'默认值'
}
}
}
script>
<style>
style>
<div>
<h1>第二个界面h1>
{{msg}}
div>
<script>
export default{
data() {
return{
msg:'默认值'
}
}
}
script>
<style>
style>
import page1 from '@/views/vuex/page1'
import page2 from '@/views/vuex/page2'
{
path: '/vuex/page1',
name: 'page1',
component: page1
},
{
path: '/vuex/page2',
name: 'page2',
component: page2
}
// 定义变量
export default {
eduName:'刘兵的爱情故事'
}
//设置值
export default {
setEeduName:(state,payload)=>{
state.eduName=payload.eduName;
}
}
state 就是 state.js文件导出的参数
payload vue 传递的参数
// /取值
export default {
getEeduName:(state)=>{
return state.eduName;
}
}
import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import getters from './getters'
import actions from './actions'
import mutations from './mutations'
Vue.use(Vuex)
const store = new Vuex.Store({
state,
getters,
actions,
mutations
})
export default store
<div style="padding: 70px;">
<h1>第一个界面h1>
<p>改变值p>
器输入你的搞笑故事<input v-model="msg">
<button @click="fun1">获取值button>
<button @click="fun2">改变值button>
div>
template>
<script>
export default {
data() {
return {
msg: '默认值'
}
},
methods: {
fun1() {
let eduNames = this.$store.state.eduName;
alert(eduNames);
},
fun2() {
this.$store.commit('setEeduName', {
eduNames:this.msg;
})
}
}
}
script>
<style>
style>
<div>
<h1>第二个界面h1>
{{eduName}}
div>
<script>
export default {
data() {
return {
msg: '默认值'
}
},
computed: {
eduName() {
return this.$store.getters.getEeduName ;
}
}
}
script>
<style>
style>
数据请求可以是异步和同步的。异步请求通常用于获取来自后端API的数据,而同步请求则可以用于更新应用程序的状态。
异步请求在Vuex中通常通过actions来处理。Actions提供了一种处理异步操作的方式,它会接收一个context对象作为参数,包含了state、commit、dispatch等属性,可以使用这些属性来获取state,触发mutations和执行另外的actions。在action中发起异步请求时,可以使用Promise或async/await来处理异步操作。当请求成功后,action会触发对应的mutation来修改store中的数据。
同步请求通常使用mutation来处理。Mutations提供了一种同步更新应用状态的方式,它接收一个state对象作为第一个参数,以及一个payload作为第二个参数,payload包含需要更新的数据。在mutation中,直接修改state的数据即可,同步更新应用状态。
需要注意的是,在Vuex中,要遵循单一状态树的原则,每个mutation或action都应该只更新一个状态。同时,应该尽量把state的状态变化集中到mutation中,避免在组件中直接修改状态,以减少应用错误和难以维护的问题。
//设置值
export default {
setEeduNameAsync: (context, payload) => {
// context vuex中的上下文
setTimeout(function() {
context.commit('setEeduName', payload);
}, 15000);
},
setEeduNameAjax: (context, payload) => {
let _this=payload._this;
let url=_this.axios.urls.VUEX_AJAX;
let params={
resturantName:payload.eduName
}
_this.axios.post(url, params).then(r => {
console.log(r)
}).catch(e => {
})
}
}
//异步请求
fun3() {
this.$store.dispatch('setEeduNameAsync', {
eduName: this.msg
})
},
fun4(){
this.$store.dispatch('setEeduNameAjax', {
eduName: this.msg,
_this:this
})
}