IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 【Vuex】Vuex搭建及多组件共享 -> 正文阅读

[JavaScript知识库]【Vuex】Vuex搭建及多组件共享

Vuex是什么

  • 概念:专门在Vue中实现集中式状态(数据)管理的一个Vue插件(Vue.use(vuex)),对Vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信.
  • Github地址: vuex官方地址

什么时候使用Vuex

  • 多个组件依赖于同一状态
  • 来自不同组件的行为需要变更同一状态

vuex4版本只支持vue3.0,所以在vue2.0中使用,
需要npm i vuex@3 指定版本

搭建vuex环境

  1. 创建文件:

src/store/index.js

//该文件用于创建vuex中最为核心的store
import Vue from "vue";
// 引入vuex
import Vuex from "vuex";
//应用vuex插件
Vue.use(Vuex);

// 准备actions,用于响应组件中的动作
const actions = {};
// 准备mutations,用于操作数据(state)
const mutations = {};
// 准备state,用于存储数据
const state = {};

// 创建并暴露store
export default new Vuex.Store({
  actions: actions,
  mutations: mutations,
  state, //简写形式
});

  1. 在main.js中创建vm时传入store配置项
.........
//引入store
import store from './store'
.........
/创建vm
new Vue({
	el:'#app',
	render:h => h(app),
	store
	)}

基本使用:

  1. 初始化数据,配置actions,配置mutations,操作文件store.js
//该文件用于创建vuex中最为核心的store
import Vue from "vue";
// 引入vuex
import Vuex from "vuex";
//应用vuex插件
Vue.use(Vuex);

// 准备actions,用于响应组件中的动作
const actions = {
//响应jia
  jia(context, value) {
    context.commit("JIA", value);
  },
};
// 准备mutations,用于操作数据(state)
const mutations = {
//执行jia
  JIA(state, value) {
    state.sum += value;
  },
};
// 准备state,用于存储数据
const state = {
  sum: 0, //当前的和
};
// 创建并暴露store
export default new Vuex.Store({
  actions: actions,
  mutations: mutations,
  state, //简写形式
});

  1. 组件中读取vuex中的sum数据:$store.state.sum (模板中写不用加this,js脚本中写需要this.$store.state.sum)
  2. 组件中修改vuex中的数据: $store.dispatch('actions中的方法名',数据)$store.commit('mutations中的方法名',数据)
  3. 若没有网络请求或者其他业务逻辑,组件也可以越过actions,即不写dispatch,直接使用commit

getters的使用:

  1. 概念:当state中的数据需要经过加工后再使用时,可以使用getters加工.
  2. 在store.js中追加getters配置
........
//准备getters,用于将state中的数据进行加工
const getters = {
  bigSum(state) {
  //要写返回值
    return state.sum * 10;
  },
};
// 创建并暴露store
export default new Vuex.Store({
  .......
  getters,
});
........
  1. 在组件中读取数据方法:$store.getters.bigSum

快速生成读取方法和使用方法

利用vuex自带的{mapState,mapGetters,mapMutations,mapActions}来方便快捷的生成代码.
首先在需要的组件文件中引入

import {mapState, mapGetters, mapMutations, mapActions} from 'vuex'
computed: {
    //可以用计算属性实现插值语法的简写
    // 程序员手写的等同于下面的mapState生成,es6写法
    // sum() {
    //   return this.$store.state.sum
    // },
    // school() {
    //   return this.$store.state.school
    // },
    //借助mapState生成计算属性,从state中读取数据.(对象写法
    ...mapState({sum: 'sum', school: 'school'}),

    //借助mapGetters生成计算属性,从state中读取数据.(数组写法
    ...mapGetters(['bigSum']),
    // bigSum() {
    //   return this.$store.getters.bigSum
    // },
  },
methods: {
    // increment() {
    //   this.$store.dispatch('jia', this.n)
    // },
    //借助mapActions生成对应方法,方法中会调用dispatch,联系actions,必须在使用时传递值 increment(n)
    ...mapActions({increment: 'jia'}),
    // decrement() {
    //   this.$store.commit('JIAN', this.n)
    // },
        //借助mapMutations生成对应方法,方法中会调用commit,联系mutations,必须在使用时传递值 decrement(n)
    ...mapMutations({decrement: 'JIAN'}),
    }

mapActions与mapMutations必须在使用时传递值例如:

<button @click = “increment(n)” > + </button>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-21 00:19:29  更:2022-09-21 00:22:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 14:47:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码