多组件共享-vuex
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的更多相关文章
- 多组件共享-vuex —— 使用vuex 报错 actions should be function or object with ”handler“
vuex分模块使用时出现的问题,单文件暂时没有用到 原因是在action 文件中没有任何定义(即:文件为空)或则 action 没有任何方法返回,将action在模块引用时去掉即可 转自:https: ...
- 前端笔记之Vue(四)UI组件库&Vuex&虚拟服务器初识
一.日历组件 new Date()的月份是从0开始的. 下面表达式是:2018年6月1日 new Date(2018, 5, 1); 下面表达式是:2018年5月1日 new Date(2018, 4 ...
- vue30-单一事件管理组件通信: vuex
------------------------------------------------------ 可以单一事件管理组件通信: vuex var Event=new Vue(); Event ...
- 使用mono-repo实现跨项目组件共享
本文会分享一个我在实际工作中遇到的案例,从最开始的需求分析到项目搭建,以及最后落地的架构的整个过程.最终实现的效果是使用mono-repo实现了跨项目的组件共享.在本文中你可以看到: 从接到需求到深入 ...
- Vue学习之--------深入理解Vuex之多组件共享数据(2022/9/4)
在上篇文章的基础上:Vue学习之--------深入理解Vuex之getters.mapState.mapGetters 1.在state中新增用户数组 2.新增Person.vue组件 提示:这里使 ...
- 父组件中vuex方法更新state,子组件不能及时更新并渲染的解决方法
场景: 我实际用到的是这样的,我父组件引用子组件related,父组件调用获取页面详情的方法,更新了state值related,子组件根据该related来渲染相关新闻内容,但是页面打开的时候总是先加 ...
- 单一事件中心管理组件通信( vuex )
有时候两个组件也需要通信(非父子关系).在简单的场景下,可以使用一个空的 Vue 实例作为中央事件总线: 补充$emit ,$on的讲解 代码: <!DOCTYPE html> <h ...
- day 87 Vue学习六之axios、vuex、脚手架中组件传值
本节目录 一 axios的使用 二 vuex的使用 三 组件传值 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 axios的使用 Axios 是一个基于 promise 的 HT ...
- vue组件化开发-vuex状态管理库
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.Vuex 也集成到 Vue 的官方调试工具 ...
随机推荐
- Beyond Compare4 激活
当你使用过一段时间后会提示有问题,需要激活或者什么. 解决办法: 找到这个路径并删除其下Beyond Compare 4文件夹即可正常使用. C:\Users\******\AppData\Roami ...
- SQLite入门语句之约束
一.SQLite约束之NOT NULL 确保某列不能有 NULL 值.默认情况下,列可以保存 NULL 值.如果您不想某列有 NULL 值,那么需要在该列上定义此约束,指定在该列上不允许 NULL 值 ...
- 非web工程,打jar放shell执行
作为6年经验的程序员,一直在搞web服务应用开发,今天领导被吐槽了,只会web方面的东东,最基本的打包啥啥都不会.. 一般开发工程都是web项目,突然要求开发非web,不用tomcat装(浪费端口号) ...
- dict用法
1 dict.items() https://www.runoob.com/python3/python3-att-dictionary-items.html 2 setdefault的用法 注意se ...
- 从Android手机中取出已安装的app包,导出apk
从Android手机中取出已安装的app包,导出apk TAG:Android,提取,apk,adb,pm,root,导出apk 假设有这样一个场景,A君看到你手机上一个实用APP,想要安装到自己手机 ...
- window10 本地搭建SVN服务器
window10本地搭建SVN服务器教程:https://www.cnblogs.com/warmlight/p/11075644.html 我按照这篇教程成功搭建SVN服务器. 有个比较坑的地方是w ...
- Python3之异常处理
写自动化脚本时经常会用到异常处理,下面将python中的异常处理做一整理: 注意:以下所有事列中的111.txt文件不存在,所以会引起异常 用法一:try...except...else..类型 1. ...
- PAT甲级终结——心得总结
首先报喜一波 第一次考,满分,4道题总共花了2个小时做完,一部分是题简单的原因,一部分也是自己三刷了PAT的心血吧. 刷PAT的经验 神指导: 胡凡-<算法笔记> 神助攻:柳婼的博客,百度 ...
- Spring源码解析-核心类之XmlBeanFactory 、DefaultListableBeanFactory
DefaultListableBeanFactory XmlBeanFactory 继承自 DefaultListableBeanFactory , 而 DefaultListableBeanFact ...
- [Python3 填坑] 018 组装类的几个例子
目录 1. print( 坑的信息 ) 2. 开始填坑 2.1 MetaClass 举例 2.2 type 举例 2.3 MetaClass 举例 1. print( 坑的信息 ) 挖坑时间:2019 ...