Online Judge——【前端项目初始化】全局状态管理

状态管理:所有页面全局共享的变量,而不是局限在某一个页面中。

适合作为全局状态的数据:比如已登录用户信息。

目录

一、创建user.ts文件

我们要实现状态管理的话,要先创建一个目录store(之前项目初始化时已经帮我们创建了),vuex就像一个中央处理库,用于在vue.js应用程序中管理共享状态(数据),如下:

  • 之后在store文件夹中建立user.js,用于专门存放用户的状态信息,简单理解就是用于保存用户的信息。
    state:存储的状态信息,比如用户信息。
    getters:便捷获取对象的一个方法
    mutation(尽量同步):定义了变量进行增删改(更新)的方法
    actions:执行异步操作,并且触发mutation的更改(可以理解为actions调用mutation)。

二、定义user模块

user.ts文件如下:

c 复制代码
// initial state
import { StoreOptions } from "vuex";

export default {
  namespaced: true,
  state: () => ({
    loginUser: {
      userName: "未登录",
    },
  }),
  actions: {
    getLoginUser({ commit, state }, payload) {
      commit("updateUser", { userName: "ly" });
    },
  },
  mutations: {
    updateUser(state, payload) {
      state.loginUser = payload;
    },
  },
} as StoreOptions<any>;

index.ts文件如下

c 复制代码
import { createStore } from "vuex";
import user from "./user";

export default createStore({
  mutations: {},
  actions: {},
  modules: {
    user,
  },
});

三、获取静态变量

cpp 复制代码
const store = useStore();
store.state.user?.loginUser

效果演示:

四、修改状态变量

代码如下:

cpp 复制代码
store.dispatch("user/getLoginUser", {
  userName: "ly",
});

代码解释:上述代码通过Vuex store的分发(dispatch)方法调用一个名为user/getLoginUser的action,并且传递了一个包含userNamely的对象作为参数。

  • store.dispatch是vuex store提供的一个方法用于分发一个action。action在vuex中执行异步操作(比如说API请求),然后将数据提交给mutations进行状态更新
  • uer/getLoginUser是action的名称;"user"是vuex模块的命名空间(namespace),getLoginUser是该模块下的一个action名称,使用命名空间可以避免action名称冲突。
  • { userName: "ly" }是传递给action的参数对象。
相关推荐
xkxnq4 分钟前
第二阶段:Vue 组件化开发(第 18天)
前端·javascript·vue.js
晓得迷路了5 分钟前
栗子前端技术周刊第 112 期 - Rspack 1.7、2025 JS 新星榜单、HTML 状态调查...
前端·javascript·html
怕浪猫8 分钟前
React从入门到出门 第五章 React Router 配置与原理初探
前端·javascript·react.js
jinmo_C++8 分钟前
从零开始学前端 · HTML 基础篇(一):认识 HTML 与页面结构
前端·html·状态模式
鹏多多15 分钟前
前端2025年终总结:借着AI做大做强再创辉煌
前端·javascript
小Tomkk23 分钟前
⭐️ StarRocks Web 使用介绍与实战指南
前端·ffmpeg
不一样的少年_27 分钟前
产品催: 1 天优化 Vue 官网 SEO?我用这个插件半天搞定(不重构 Nuxt)
前端·javascript·vue.js
-dcr29 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
行者9638 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang39 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习