Vue总结第六天:Vuex (全局变量管理~多个页面共享数据)

简介: Vue总结第六天:Vuex (全局变量管理~多个页面共享数据)

目录

一、Vuex (全局变量管理~~多个页面共享数据)

✿ 更详细的可以看官网:开始 | Vuex

1、什么是Vuex?

2、核心概念:

(1) state:保存共享的状态(全局变量)

(2) getters(类似计算属性)

(3) mutations:(类似于事件注册) Vuex的store状态的更新唯一方式:提交Mutation

   1)Mutation主要包括两部分:

   2)使用:

   3)提交载荷(Payload):就是mutations回调函数的参数(可以是基本变量,也可以是对象):

  4)提交风格:

  5)使用常量替代 Mutation 事件类型:

  6)在组件中提交 Mutation(简化方法的调用代码):使用 mapMutations 辅助函数将组件中的 methods 映射为 store.commit 调用

(4) actions(异步操作):actions提交的对象是 mutation,而不是直接变更状态state:

  1)Action 函数有一个与 store 实例具有相同方法和属性的 context 对象,

  2) Action作用:

  3) 使用:

  4)提交载荷(Payload)---actions和mutations的回调函数的参数:

  5)Action返回Promise对象,将异步操作后的结果返回给vue实例method中定义分发的函数。

  6)在组件中分发 Action(简化方法的调用代码): mapActions 辅助函数将组件的 methods 映射为 store.dispatch

(5) modules(模块化):

 

 

一、Vuex (全局变量管理~~多个页面共享数据)

           ✿ 更详细的可以看官网:https://vuex.vuejs.org/zh/guide/


43.png44.png


45.png


const store = new Vuex.Store({
  state: {
      count: 1
  },
  mutations: {
    increment (state) {
      // 变更状态
      state.count++
    }
  }
})
//提交mutations
this.$store.commit('increment', 10)

464.png


vue 实例中定义的method方法中:通过 this.$store.commit('increment'),

其中这个 'increment' 就是咱定义在store的mutitions中的回调函数名


47.png


//注册increment事件
mutations: {
  increment (state, n) {
    state.count += n
  }
}


//提交mutations
this.$store.commit('increment', 10)


48.png

//注册increment事件
mutations: {
  increment (state, payload) {
    state.count += payload.amount
  }
}


//提交mutations
this.$store.commit('increment', {
  amount: 10
})


49.png

50.png


//注册一个increment的action,并通过context提交个mutations
const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    }
  },
  actions: {
//写法一:直接书写context对象    
    increment (context) {
      context.commit('increment')
    }
//写法二:直接书写context对象需要用到的属性或方法    
    increment ({commit}) {
      commit('increment')
    }
  }
})


51.png

this.$store.dispatch('increment');


52.png

53.png

54.png



目录
相关文章
|
1天前
|
移动开发 前端开发
ruoyi-nbcio-plus基于vue3的flowable的支持自定义业务流程处理页面detail.vue的升级修改
ruoyi-nbcio-plus基于vue3的flowable的支持自定义业务流程处理页面detail.vue的升级修改
|
1天前
|
JavaScript
vue打印v-model 的值
vue打印v-model 的值
|
1天前
|
JavaScript
Vue实战-组件通信
Vue实战-组件通信
7 0
|
1天前
|
JavaScript
Vue实战-将通用组件注册为全局组件
Vue实战-将通用组件注册为全局组件
7 0
|
1天前
|
JavaScript 前端开发
vue的论坛管理模块-文章评论02
vue的论坛管理模块-文章评论02
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
989 0
|
1天前
|
JavaScript
VUE里的find与filter使用与区别
VUE里的find与filter使用与区别
20 0
|
1天前
|
JavaScript
vue页面加载时同时请求两个接口
vue页面加载时同时请求两个接口
|
1天前
|
JavaScript
vue里样式不起作用的方法,可以通过deep穿透的方式
vue里样式不起作用的方法,可以通过deep穿透的方式
14 0
|
1天前
|
移动开发 JavaScript 应用服务中间件
vue打包部署问题
Vue项目`vue.config.js`中,`publicPath`设定为"/h5/party/pc/",在线环境基于打包后的`dist`目录,而非Linux的`/root`。Nginx代理配置位于`/usr/local/nginx/nginx-1.13.7/conf`,包含两个相关配置图。
vue打包部署问题