1、解决多个组件共享同一状态数据问题
1)多个视图共享同一状态
2)来自不同视图的触发事件需要变更同一状态
文档API:https://vuex.vuejs.org/zh/api/

2、组件与store连接桥梁
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>',
  store // 所有的组件多了一个 $store属性
})
1)模板显示 $store.state.xxx
2)计算属性 this.$store.getters.yyy
3)触发事件 this.$store.dispatch('') 来调用actions中函数

actions:

1、存放触发事件函数的对象
2、通过执行commit('') 调用mutations中函数间接更新state
mutations:存放更新状态函数的对象
state: 存放状态的对象
getters: 存放计算属性函数的对象

1、store.js文件
import Vuex from 'vuex'
import Vue from 'vue'
Vue.use(Vuex)
const state = {
num: 0
}
const mutations = {
addNums: function (state) {
state.num++
},
releaseNums: function (state) {
state.num--
if (state.num < 0 ){
state.num = 0
}
}
}
const actions = {
addNum: function ({commit}) {
commit('addNums')
},
releaseNum: function ({commit}) {
commit('releaseNums')
}
}
const getters = {
reverseonum: function (state) {
return state.num * 2
}
}
export default new Vuex.Store({
state,
mutations,
actions,
getters
})
2、组件
<template>
<div>
<div>
<button @click="release">减少</button>
<input type="text" v-model="$store.state.num"/>
<button @click="add">增加</button>
</div>
<div>
{{ reversedMessage }}
</div>
</div>
</template>
<script>
export default {
computed: {
reversedMessage: function () {
return this.$store.getters.reverseonum
}
},
methods: {
add: function () {
this.$store.dispatch('addNum')
},
release: function () {
this.$store.dispatch('releaseNum')
}
}
}
</script>
【简化方式】
<template>
<div>
<div>
<button @click="releaseNum">减少</button>
<input type="text" v-model="num"/>
<button @click="addNum">增加</button>
</div>
<div>
{{ reverseonum }}
</div>
</div>
</template>
<script>
import { mapState, mapGetters, mapActions } from 'vuex'
export default {
computed: {
...mapState(['num']), //返回值{ num(){ return this.$store.state['num']}}
...mapGetters(['reverseonum'])
//返回值{ reverseonum(){ return this.$store.state['reverseonum']}}
//这里等同于 ...mapGetters({reversedMessage: 'reverseonum'}) ,所以上面只是前后方法名需相同
},
methods: {
...mapActions(['addNum', 'releaseNum'])
}
}
</script>

多组件共享-vuex的更多相关文章

  1. 多组件共享-vuex —— 使用vuex 报错 actions should be function or object with ”handler“

    vuex分模块使用时出现的问题,单文件暂时没有用到 原因是在action 文件中没有任何定义(即:文件为空)或则 action 没有任何方法返回,将action在模块引用时去掉即可 转自:https: ...

  2. 前端笔记之Vue(四)UI组件库&Vuex&虚拟服务器初识

    一.日历组件 new Date()的月份是从0开始的. 下面表达式是:2018年6月1日 new Date(2018, 5, 1); 下面表达式是:2018年5月1日 new Date(2018, 4 ...

  3. vue30-单一事件管理组件通信: vuex

    ------------------------------------------------------ 可以单一事件管理组件通信: vuex var Event=new Vue(); Event ...

  4. 使用mono-repo实现跨项目组件共享

    本文会分享一个我在实际工作中遇到的案例,从最开始的需求分析到项目搭建,以及最后落地的架构的整个过程.最终实现的效果是使用mono-repo实现了跨项目的组件共享.在本文中你可以看到: 从接到需求到深入 ...

  5. Vue学习之--------深入理解Vuex之多组件共享数据(2022/9/4)

    在上篇文章的基础上:Vue学习之--------深入理解Vuex之getters.mapState.mapGetters 1.在state中新增用户数组 2.新增Person.vue组件 提示:这里使 ...

  6. 父组件中vuex方法更新state,子组件不能及时更新并渲染的解决方法

    场景: 我实际用到的是这样的,我父组件引用子组件related,父组件调用获取页面详情的方法,更新了state值related,子组件根据该related来渲染相关新闻内容,但是页面打开的时候总是先加 ...

  7. 单一事件中心管理组件通信( vuex )

    有时候两个组件也需要通信(非父子关系).在简单的场景下,可以使用一个空的 Vue 实例作为中央事件总线: 补充$emit ,$on的讲解 代码: <!DOCTYPE html> <h ...

  8. day 87 Vue学习六之axios、vuex、脚手架中组件传值

      本节目录 一 axios的使用 二 vuex的使用 三 组件传值 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 axios的使用 Axios 是一个基于 promise 的 HT ...

  9. vue组件化开发-vuex状态管理库

    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.Vuex 也集成到 Vue 的官方调试工具 ...

随机推荐

  1. SpringBoot:初识SpringBoot

    西部开源-秦疆老师:基于SpringBoot 2.1.6 的博客教程 秦老师交流Q群号: 664386224 未授权禁止转载!编辑不易 , 转发请注明出处!防君子不防小人,共勉! 1.SpringBo ...

  2. shouyexinlianjie

    http://7xj7xs.com1.z0.glb.clouddn.com/trail_1.mp4

  3. canvas介绍(画布)

    canvas(画布)主要是位图 svg(矢量图) canvas标签,必须要写的3个属性 id width height 为什么不再style中设置width和height呢? 因为这设置width和h ...

  4. 关于【C++项目:无法解析的外部符号】

    1,基本原因,[链接器]->[附加库目录]没有填写相关库的路径.或没有在[链接器]->[输入]->[附加依赖项]中填写相关库的名称 2,高级原因:如果不是1的原因,那就有可能是平台与 ...

  5. 【C++进阶:移位运算符的用法】

    数据在计算机中以补码存储 移位运算符:<<  左移运算符 >>  右移运算符 一丶 << 左移运算符 移位规则:左边抛弃,右边补零 int num=10; num& ...

  6. Eclipse Java工程转为Web工程步骤

    找到工程的.project文件,在<natures>标签中增加以下两行配置:<nature>org.eclipse.wst.common.modulecore.ModuleCo ...

  7. dig中文帮助

    NAME(名称)     dig — 发送域名查询信息包到域名服务器 SYNOPSIS(总览)     dig [@server] domain [⟨query-type⟩] [⟨query-clas ...

  8. Week 10 - 474. Ones and Zeroes

    474. Ones and Zeroes In the computer world, use restricted resource you have to generate maximum ben ...

  9. Java 基础-类与面向对象

    类 Object 类(java.lang.Object)是所有 Java 类的直接或间接父类. 成员方法及变长参数 方法定义: [public | protected | private] [stat ...

  10. 【SD系列】SAP SD模块-公司间销售简介

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[SD系列]SAP SD模块-公司间销售简介   ...