Vuex的基本使用

这篇具有很好参考价值的文章主要介绍了Vuex的基本使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  • Vuex基本使用

  • 1 Vuex 是什么

  • Vuex 是vue中特别重要的一个技术,专门在vue中实现集中式状态(数据)管理的一个vue插件,对vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信
  • Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 + 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
  • 更多关于Vuex的介绍,可以参考Vuex 官网:https://vuex.vuejs.org/zh/
  • Vuex的基本使用
  • github地址:https://github.com/vuejs/vuex

2 什么时候使用vuex

1 多个组件依赖于同一状态

2 来自不同组件的行为需要更改同一状态

简单来说就是:多个组件需要共享数据时

为了说明vuex的作用,下面展示一个求和案例,分别使用纯vue和Vuex 来实现

3 基本使用(求和案例)

纯vue实现

首先使用纯vue实现

Vuex的基本使用

效果如下

Vuex的基本使用

注意观察,现在的sum属性都是在count这个组件中使用的,一会我们改造这个案例的时候,把它交给vuex管理再进行对比

<template>
    <div>
       <h3>当前求和为:{{sum}}</h3>
       <select v-model.number="n">
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
       </select>
       <button @click="increment">+</button>
       <button @click="decrement">-</button>
       <button @click="incrementOdd">当前求和为基数再加</button>
       <button @click="incrementWait">等一等再加</button>
    </div>
</template>

<script>
    export default {
        name:'Count',
        data() {
            return {
                n:1, // 用户选择的数字
                sum:0 // 当前的和
            }
        },
        methods: {
            increment(){
                this.sum+=this.n
            },
             decrement(){
                 this.sum-=this.n
            },
             incrementOdd(){
                if(this.sum % 2){
                     this.sum+=this.n
                }
            },
             incrementWait(){
                setTimeout(() => {
                     this.sum+=this.n
                }, 500);
            }
        },
      
    }
</script>
<style scoped>
    button{
        margin-left: 5px;
    }
</style>

   
字符串转数字

在做这个案例的时候,我发现一个小问题,就算获取下拉框的option的value属性时,是一个字符串,如果相加就会造成字符串拼接,针对这种情况,我们有两种解决方式

解决方式1

给option的value属性加一个:,表示这是一个js表达式

Vuex的基本使用

解决方式2

无需上面这么麻烦,还要给每一个value属性加:,可以使用v-model.number进行强转

Vuex的基本使用

求和案例(vuex实现)

首先要确保搭建vuex开发环境

安装好了vuex之后,就可以对案例进行改造了,下面使用vuex实现

首先把sum放到state里面

Vuex的基本使用

这时候报错了,因为actions里面没有increment这个类型

Vuex的基本使用

所以需要给actions里面加入一个increment类型,它是一个函数,有两个参数

参数1:迷你版的store,因为它也有commit,dispatch等api,官方叫做上下文

参数2:传入参数的值

Vuex的基本使用

Vuex的基本使用

既然知道了参数,就可以使用commit操作了

Vuex的基本使用

这时候又报错了,这次是mutation的原因

Vuex的基本使用

这里有一个开发小技巧,在编写action进行commit的时候,函数名可以大写,这样就知道要借给mutation进行操作了,mutation可以直接操作属性的值

mutation也有两个参数

参数1是 state,里面存放在属性并且进行数据监视

参数2还是属性的值

Vuex的基本使用

Vuex的基本使用

既然知道了参数就可以进行逻辑操作了

Vuex的基本使用

这样就正常了

Vuex的基本使用

继续补充其他的逻辑

Vuex的基本使用

虽然可以完成功能,但是可以优化下代码,把判断和定时器放到action里面处理

全部的业务逻辑处理都要在action里面完成,mutation只是负责执行

Vuex的基本使用

但是发现,上面两个action的作用很鸡肋,这时候我们可以在组件里面使用commit调用mutation,如果使用dispatch是和action进行对话的

Vuex的基本使用

这样一个基本的vuex使用就完成了,这只是一个最基础的,后续会继续升级的

4 Vuex工作原理图

以下这张图是Vuex官网发布的,这张图忽略(没有体现出来)两个地方

首先是一个重要的角色:store

Actions,Mutations,State虽然都是Vuex里面的部分,但是实际上都是由store管理的,像dispatch,commit,也是store的方法

每一个 Vuex 应用的核心就是 store(仓库)。“store”基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。Vuex 和单纯的全局对象有以下两点不同:

  1. Vuex 的状态存储是响应式的。当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新。
  2. 你不能直接改变 store 中的状态。改变 store 中的状态的唯一途径就是显式地提交 (commit) mutation。这样使得我们可以方便地跟踪每一个状态的变化,从而让我们能够实现一些工具帮助我们更好地了解我们的应用

然后就算VueComponents有的场景是可以直接和Mutations进行打交道的,而不用过Actions

Vuex的基本使用

具体的工作原理可以参考官网或者其他大牛写的相关文章,个人作为初学者就不过多解释了

5 基本使用总结

1 初始化数据、配置actions、配置mutations,操作文件store.js

//引入Vue核心库
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//引用Vuex
Vue.use(Vuex)

const actions = {
    //响应组件中加的动作
        jia(context,value){
                // console.log('actions中的jia被调用了',miniStore,value)
                context.commit('JIA',value)
        },
}

const mutations = {
    //执行加
        JIA(state,value){
                // console.log('mutations中的JIA被调用了',state,value)
                state.sum += value
        }
}

//初始化数据
const state = {
   sum:0
}

//创建并暴露store
export default new Vuex.Store({
        actions,
        mutations,
        state,
})

2 组件中读取vuex中的数据:$store.state.sum

3 组件中修改vuex中的数据:$store.dispatch('action中的方法名',数据)$store.commit('mutations中的方法名',数据)

备注:若没有网络请求或其他业务逻辑,组件中也可以越过actions,即不写dispatch,直接编写commit文章来源地址https://www.toymoban.com/news/detail-500799.html

到了这里,关于Vuex的基本使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【初阶C语言3】特别详细地介绍函数以及在初阶中重要的算法——递归

     💓作者简介: 加油,旭杏,目前大二,正在学习 C++ , 数据结构 等👀 💓作者主页:加油,旭杏的主页👀 ⏩本文收录在:再识C进阶的专栏👀 🚚代码仓库:旭日东升 1👀 🌹欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖💖        从标题也能看出来,我们有要进行 超详细

    2024年02月08日
    浏览(47)
  • sshfs 的安装和基本使用方式,重要参数解释

      sshfs 是 ssh file system 的缩写,是基于 ssh 协议设计的一种文件系统,主要用于通过TCP网络将远程 ssh 服务器中的文件(夹)挂载到另一台机器上,包括本地机器,以便于对文件夹中的文件进行访问;配置便捷,使用安全,轻松访问;     在 ubuntu 上安装 sshfs        -o allo

    2024年02月06日
    浏览(50)
  • vuex 的基本用法

    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用 集中式存储管理 应用的所有组件的状态, 这个状态管理应用包含以下几个部分: state,驱动应用的数据源; view,以声明方式将 state 映射到视图; actions,响应在 view 上的用户输入导致的状态变化。 给出一张官方的

    2024年02月11日
    浏览(27)
  • 为什么sessionStorage不能代替vuex

    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 译为“会话存储”,也是HTML5新增的一个存储对象, 用于本地临时存储同一窗口的数据,在 关闭窗口之后 将会删除这

    2024年02月09日
    浏览(70)
  • 工具︱ Web3加密浏览器Brave有什么特别之处?

    使用浏览器来上网访问和获取各种信息和资源已经成为传统互联网民的普遍活动, 下一代互联网协议Web3的核心特点是去中心化 ,即不依赖于中心化的服务器和数据中心,而是通过分布式的网络节点来实现数据存储和传输。 浏览器承载着信息网络与用户需求的智能枢纽,也是

    2024年02月06日
    浏览(45)
  • 什么是 Spring 框架?使用 Spring 框架的好处是什么?Spring 框架中用到了哪些设计模式?列举一些重要的Spring模块?

    Spring 是一种轻量级开发框架,旨在提高开发人员的开发效率以及系统的可维护性。 Spring 官网 :https://spring.io/ Spring 框架指的是 Spring Framework ,它是很多模块的集合,使用这些模块可以很方便地协助我们进行开发。         这些 模块 是:核心容器、数据访问/集成,、Web、

    2024年02月13日
    浏览(45)
  • vuex前端开发,getters是什么?怎么调用?简单的案例操作

    vuex前端开发,getters是什么?怎么调用?简单的案例操作! 下面通过一些简单的案例,来了解一下,vuex当中的getters到底是什么意思,有哪些实际的操作案例。 Vuex的getters主要用于对 store中的state进行计算或过滤 ,类似于Vue组件中的 计算属性 。它可以对state进行一些处理,然后

    2024年01月19日
    浏览(44)
  • Cilium 系列-3-Cilium 的基本组件和重要概念

    Cilium 系列文章 安装完了,我们看看 Cilium 有哪些组件和重要概念。 如上所述,安装 Cilium 时,会安装几个运行组件(有些是可选组件), 它们各是什么用途? Cilium Operator 可以理解为 Cilium 的管理平面或操作运维平面。Cilium Operator 不处于任何转发或网络策略决策的关键路径上

    2024年02月16日
    浏览(41)
  • 什么是 sudo,为什么它如此重要?

    在当今的技术世界中,Linux 操作系统广泛应用于各种环境,包括个人计算机、服务器和嵌入式设备。作为一种强大的开源操作系统,Linux 提供了丰富的安全功能,以保护系统和用户的数据安全。在 Linux 安全领域中,sudo 是一项关键的安全工具,它在用户权限管理和系统保护方

    2024年02月06日
    浏览(44)
  • 为什么软件架构重要?

    作者:[美]伦·巴斯等 第2章为什么软件架构重要 如果架构是答案,那么问题是什么? 本章主要从技术角度讨论为什么架构重要。我们将研究13个重要原因。你可以利用它们来推动新架构的创建,或者对已有系统架构进行分析和优化。 1)架构可以抑制或支持系统的质量属性。

    2024年02月13日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包