快速了解Vuex

Vuex

Vuex

📌vuex 是一个专为 Vue.js 应用程序开发的状态管理库

📌vuex 可以在多个组件之间共享数据,并且共享的数据是响应式的,即数据的变更能及时渲染到模板

📌vuex 采用集中式存储管理所有组件的状态(将公用的数据提取出来集中存储)

进行安装
npm install vuex@next --save

state:状态对象,集中定义各个组件共享的数据
mutations:类似一个事件,用于修改共享数据,要求必须是同步函数
actions:类似于mutation,可以包含异步操作,通过调用mutation来改变共享数据


使用Vuex

使用需要创建带有vuex功能的脚手架工程

创建好之后就是一个基础的index.js文件

js 复制代码
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
  },
  getters: {
  },
  mutations: {
  },
  actions: {
  },
  modules: {
  }
})

如何定义共享数据:

js 复制代码
  state: {
      name: '你好'
  },

这样在我们的页面中就会展示出定义的共享数据
如何展示呢

html 复制代码
<div id="app">
   {{$store.state.name}}
</div>

如何修改共享数据

js 复制代码
mutations:{
    setName(state,Newname){
     state.name=Newname
    }
}

那么如何修改,修改需要通过事件调用函数进行改变

js 复制代码
methods: {
    handleUpdate(){
    //第一个参数是对应的函数名称,第二个是参数
      this.$store.commit('setName','我好')
    }
}
  • 如果要进行异步操作

数据不是我们指定的,需要axios请求后端

就像初始界面,我们登录进去会显示谁谁谁你好,这个数据就是后端提供的
需要在actions中进行定义方法

js 复制代码
  mutations: {
  },
  actions: {
    setNameaxios(context){
      axios({
        url: '/login',
        method: 'post',
        data: {
          username: 'hlh',
          password: '123456'
        }
      }).then(res=>{
        if(res.data.code==1){
          context.commit('setName',res.data.data.name)
        }
      })
    }
  },

其中的context是一个上下文对象,通过它可以调用store中的上下文
同样也需要监听函数进行调用调用actions中定义的函数

js 复制代码
methods: {
    handleUpdate2(){
    //第一个参数是对应的函数名称,第二个是参数
      this.$store.dispatch('setNameaxios')
    }
}

附录:注意

发送请求就涉及到了跨域问题,在前端代码中我们可以在vue.config.js文件中配置代理

js 复制代码
  devServer:{
    port: 8081,
    proxy:{
      '/login':{
        target:'http://localhost:8080'
      }
    }
  }
相关推荐
瓯雅爱分享2 小时前
Java+Vue构建的采购招投标一体化管理系统,集成招标计划、投标审核、在线竞价、中标公示及合同跟踪功能,附完整源码,助力企业实现采购全流程自动化与规范化
java·mysql·vue·软件工程·源代码管理
苏打水com6 小时前
前端框架深度解析:Vue 从入门到实战,掌握渐进式开发核心
vue
棋子一名16 小时前
跑马灯组件 Vue2/Vue3/uni-app/微信小程序
微信小程序·小程序·uni-app·vue·js
苏打水com18 小时前
前端框架深度解析:Vue.js 3 从 Composition API 到生态升级,解锁企业级开发新能力
vue
知识分享小能手1 天前
微信小程序入门学习教程,从入门到精通,微信小程序核心 API 详解与案例(13)
前端·javascript·学习·react.js·微信小程序·小程序·vue
小灰灰的可爱无人可替代1 天前
记录一次使用docker和docker-compose更新vue前端项目问题
nginx·docker·vue
java水泥工2 天前
酒店客房管理系统|基于SpringBoot和Vue的酒店客房管理系统(源码+数据库+文档)
spring boot·vue·酒店管理系统·酒店客房管理系统
爱看书的小沐4 天前
【小沐学WebGIS】基于Three.JS绘制飞行轨迹Flight Tracker(Three.JS/ vue / react / WebGL)
javascript·vue·webgl·three.js·航班·航迹·飞行轨迹
知识分享小能手5 天前
微信小程序入门学习教程,从入门到精通,WXS语法详解(10)
前端·javascript·学习·微信小程序·小程序·vue·团队开发
知识分享小能手5 天前
微信小程序入门学习教程,从入门到精通,WXSS样式处理语法基础(9)
前端·javascript·vscode·学习·微信小程序·小程序·vue