当前位置: 首页 > news >正文

vue基础——java程序员版(vuex)

​ vuex可以定义共享数据。

1、主要结构

src/store/index.js 是使用vuex的核心js文件。

  • 定义数据:state

  • 修改数据(同步):mutations

  • 修改数据(异步):action=调用=>mutations

    下面定义了一个公共数据msg ,mutations方法setName,action方法sendAjax

import Vue from 'vue'
import Vuex from 'vuex'Vue.use(Vuex)export default new Vuex.Store({// 定义共享数据,{{$store.state.msg}}展示,所以得组件都可以使用state: {msg:'这是vuex的公共消息',},getters: {},// 只能由mutations来实现修改,必须是同步操作mutations: {// state代表的是上面的state必须同名,但是后面的参数是形参名字随意,调用:this.$store.commit('setName','新的信息!');setName(state,newMsg){state.msg=newMsg;}},// action可以调用mutations,在action可以执行异步操作(Ajax),调用:this.$store.dispatch('sendAjax');actions: {// 通过传入context来调用mutations方法sendAjax(context){/*** 执行Ajax*/context.commit('setName','异步修改的信息');},},modules: {}
})

2、操作共享数据

​ {{$store.state.msg}}展示数据msg,update1()调用mutations的setName方法修改msg,update2()调用action的sendAjax方法修改msg。

<template>
<div><h1>{{$store.state.msg}}</h1><input type="button" value="直接修改共享数据" @click="update1()"/><input type="button" value="异步修改共享数据" @click="update2()"/>
</div>
</template>
<script>export default {methods:{update1(){// 第一个参数是mutations定义的函数名,第二个是参数this.$store.commit('setName','新的信息!');},update2(){// 调用action方法,指定调用的函数名this.$store.dispatch('sendAjax');}}}
</script>
http://www.lryc.cn/news/324665.html

相关文章:

  • ubuntu20.04安装 ffmpeg 开发环境
  • 微软开源Garnet高性能缓存服务安装
  • 云计算系统管理(ADMIN)
  • Spark spark-submit 提交应用程序
  • IOS面试题编程机制 51-55
  • 话题——AI大模型学习
  • MySQL基础复习
  • Zookeeper(八)序列化与协议
  • 人工智能之Tensorflow变量作用域
  • ElasticSearch插件安装及配置
  • vue+Echarts实现多设备状态甘特图
  • STM32使用滴答定时器实现delayms
  • k8s的volumn解析
  • Golang获取音视频时长信息
  • LeetCode 面试经典150题 14.最长公共前缀
  • 自注意力机制的理解
  • win10-误删winsock恢复方法
  • c#矩阵求逆
  • array go 语言的数组 /切片
  • 【Stable Diffusion】专栏介绍和文章索引(持续更新中)
  • RPC 快速入门
  • 使用Docker搭建Syslog-ng
  • 使能 Linux 内核自带的 FlexCAN 驱动
  • 通过dbeaver链接dm8数据库
  • Stable diffusion(四)
  • oracle 19c RAC补丁升级
  • 计算机视觉研究方向
  • 数据分析-Pandas分类数据的比较如何避坑
  • P - Beat
  • 机器学习——GBDT算法