Vuex的简介以及入门案例

简介: Vuex的简介以及入门案例

Vuex介绍

Vuex是一种状态管理模式,它专为Vue.js应用程序开发设计。使用Vuex能够更好地组织Vue.js应用中的代码,并使代码更容易理解和维护。

Vuex把应用的状态(数据)集中存储到一个全局的store对象中,并使用mutations(同步任务)和actions(异步任务)来修改状态。Vuex的数据流是单向的,当组件需要更新状态时,它将发起一个action,action又会commit一个mutation,mutation会修改state,state的变化会自动更新到所有涉及该状态的组件视图中。


Vuex的核心概念包括state、getter、mutation、action、module等。


- State:即应用的状态,存储到一个全局的store对象中。

- Getter:类似于computed,用来对state进行计算,返回派生状态。

- Mutation:修改state的唯一途径,在mutation函数内部修改state,且必须是同步的。

- Action:异步操作的行为,可以包含多个mutation,通过dispatch来触发action。

- Module:将大型的store拆分为多个小模块,每个小模块都有自己的state、getter、mutation、action。


总之,Vuex是Vue.js应用中一种非常实用的状态管理工具,让我们可以更好地管理和维护应用的状态数据。

图像解析

官方图像解析

传值的图像解析  

Vuex的入门案例

下载我们的Vuex的插件   npm install vuex -S

Vuex的存值和取值

搭建Vue界面
page1
<template>
  <div style="padding: 70px;">
    <h1>第一个界面</h1>
    <p>改变值</p>
    请输入<input v-model="msg">
    <button @click="fun1">获取值</button>
    <button @click="fun2">改变值</button>
    <button @click="fun3">改变值(异步请求)</button>
    <button @click="fun4">改变值(异步请求后台数据)</button>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        msg: '默认值'
      }
    },
    methods: {
      fun1() {
        let eduNames = this.$store.state.eduName;
        alert(eduNames);
      },
      fun2() {
        this.$store.commit('setEeduName', {
          eduName: this.msg
        })
      },
      //异步请求
      fun3() {
        this.$store.dispatch('setEeduNameAsync', {
          eduName: this.msg
        })
      },
      fun4(){
       this.$store.dispatch('setEeduNameAjax', {
         eduName: this.msg,
         _this:this
       })
      }
    }
  }
</script>
<style>
</style>

page2

<template>
  <div>
    <h1>第二个界面</h1>
    {{eduName}}
  </div>
</template>
<script>
  export default {
    data() {
      return {
        msg: '默认值'
      }
    },
    computed: {
      eduName() {
        return this.$store.getters.getEeduName;
      }
    }
  }
</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
        }
定义变量

在我们的state.js中定义变量

//  定义变量
export  default {
    eduName:'5211314'
}
mutations.js
//设置值
export  default {
    setEeduName:(state,payload)=>{
       state.eduName=payload.eduName;
    }
}
getter.js
// /取值
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

目录
相关文章
|
SQL 数据库
SQL 中的 MIN 和 MAX 以及常见函数详解及示例演示
SQL中的MIN()函数和MAX()函数用于查找所选列的最小值和最大值,分别。以下是它们的用法和示例:
581 0
|
7月前
|
机器学习/深度学习 人工智能 自然语言处理
AI训练师入行指南(三):成熟AI模型与自研如何选择?
本文为AI训练师提供选型指南,探讨使用成熟模型还是自研算法。内容涵盖NLP、CV和多模态场景下主流模型推荐,如DeepSeek-Chat、GPT-4o、ResNet-50等,以及自研模型的应用场景与技术实现。同时提供懒人四步决策法和避雷口诀,帮助快速选择适合的工具。新手建议从预训练模型入手,逐步深入魔改或自研,避免常见坑点。附带场景化对比表,助力高效决策。
285 5
|
Java 数据处理
Java运算符与表达式详解
Java运算符与表达式详解
|
前端开发 Shell Go
微服务效率工具 goctl 深度解析(上)
微服务效率工具 goctl 深度解析(上)
Matlab批量修改指定文件下文件名
Matlab批量修改指定文件下文件名
437 1
|
存储 人工智能 算法
AI与大数据的结合:案例分析与技术探讨
【8月更文挑战第22天】AI与大数据的结合为各行各业带来了前所未有的机遇和挑战。通过具体案例分析可以看出,AI与大数据在电商、智能驾驶、医疗等领域的应用已经取得了显著成效。未来,随着技术的不断进步和应用场景的不断拓展,AI与大数据的结合将继续推动各行业的创新与变革。
|
监控 安全 网络安全
恶意软件分析:解析与实践指南
【8月更文挑战第31天】
618 0
|
编解码 移动开发 前端开发
web canvas系列——快速入门上手绘制二维空间点、线、面
web canvas系列——快速入门上手绘制二维空间点、线、面
471 4
计算机网络——数据链路层-封装成帧(帧定界、透明传输-字节填充,比特填充、MTU)
计算机网络——数据链路层-封装成帧(帧定界、透明传输-字节填充,比特填充、MTU)
830 0