vue3+Ts使用vuex模块化和非模块化管理的2种方式(非pinia)

news2024/12/26 11:11:55

官网写的很清楚:https://vuex.vuejs.org/zh/guide/typescript-support.html
在这里插入图片描述
2种方式 (都不是使用pinia的)

1:复杂版本(不定义自己的 useStore 组合式函数)

使用的时候需要在vuex引入 useStore 在store文件引入导出的key
import { useStore } from ‘vuex’
import { key } from ‘./store’

import { createStore } from "vuex";
import type { InjectionKey } from "vue";
import type { Store } from "vuex";
//这个是定义的接口用来限制store的参数类型
export interface State {
  count: number;
  
}
// 定义 injection key
// 导出对象下的变量 需要在mian.ts引入key 
export const key: InjectionKey<Store<State>> = Symbol()
 
export default createStore<State>({
  //加类型注解 里面的参数才会生效 
  state: { count: 211 },
  getters: {
    // dobuleCount:state=>state.count*2,
    // 或者
    dobuleCount(state){return  state.count*2}
  },
  mutations: {
    add(state,payload:number){
      console.log(state.count)
    }
  },
  actions: {},
  modules: {},
});

vue组件使用:

import { useStore } from "vuex";
import { key } from "../store";//自己的store文件
let store = useStore(key);
console.log(store.state.count)//211

2:简单版本

ts两处变化:
1:import { useStore as baseUseStore } from “vuex”;
2:export function useStore () { return baseUseStore(key)//把key导出去了 }
vue使用变化:
import { useStore } from ‘…/store’

import { createStore } from "vuex"; 
import type { InjectionKey } from "vue";
import type { Store } from "vuex";
//useStore as baseUseStore,就这里有个变化
import   { useStore as baseUseStore } from "vuex";

// 限制类型
export interface State {
  count: number;
  
}
 export const key: InjectionKey<Store<State>> = Symbol();
 
 
export default createStore<State>({
  //加类型注解 里面的参数才会生效 
  state: { count: 211 },
  getters: {
    // dobuleCount:state=>state.count*2,
    // 或者
    dobuleCount(state){return  state.count*2}
  },
  mutations: {
    add(state,payload:number){
      console.log(state.count)
    }
  },
  actions: {},
  modules: {},
});
// 定义自己的 `useStore` 组合式函数 这里也有了变化
 export function useStore () {
   return baseUseStore(key)//把key导出去了
 }

vue组件使用:(不需要引入key 引入useStore不在需要在vuex引入)

  import { useStore } from '../store'
  let store = useStore(); 
  console.log(store.state.count)

以上两种方式的 在main.ts引入是一致的

import store, { key } from "./store";
createApp(App).use(store,key).mount('#app')

vuex使用模块化modules
新建一个modules文件夹 因为这是模块不是vuex默认的index.ts所以很多类型需要自己去写限制
在这里插入图片描述
// 不知道什么类型 把鼠标悬浮到默认的index.ts文件下的mutation上获取mutation的类型依次操作(action,getters…)…
在这里插入图片描述
users.ts文件

import  type {MutationTree,ActionTree,GetterTree}  from 'vuex'
import  type  {State}  from '../index'
定义类型限制接口interface
export  interface UsersState{
    username:string,
    age:number
}


let state:UsersState = {
    username:'zhuzhu',
    age:121
};
//<UsersState,State>//参数1是为了访问当前模块下的state的变量  参数2是引入的主模块下的
//不知道类型注解几个参数看上图
let getters:GetterTree<UsersState,State> = {
    // dobulecount:state=>state.age*2
    // 或者
    dobulecount(state){
        return state.age*2
    }
};
let mutations:MutationTree<UsersState> = {
    change(state){
        console.log(state.age)
    }
};
let actions:ActionTree<UsersState,State> = {};
export default {
  namespace: true,//开始模块命名空间
  state,
  getters,
  mutations,
  actions,
};

index.ts主模块引入modules (使用上面的简单案例代码进行描述

import { createStore } from "vuex";
import type { InjectionKey } from "vue";
import type { Store } from "vuex"; 
import   { useStore as baseUseStore, } from "vuex"; 
import users from "./modules/users";
// 引入模块下的文件类型
import { UsersState } from "./modules/users";
// 限制类型
export interface State {
  count: number;
  
}
//继承主模块下的接口 (变化部分)
interface StateAll extends State{
   users:UsersState, //UsersState是上面引入的类型 users是自己定义的名
   //若是多个模块  依次类推
}

//这个就不可使用了 要换成下面的继承之后的接口
// export const key: InjectionKey<Store<State>> = Symbol();
 export const key: InjectionKey<Store<StateAll>> = Symbol();
 
export default createStore<State>({
  //加类型注解 里面的参数才会生效 
  state: { count: 211 },
  getters: {
    // dobuleCount:state=>state.count*2,
    // 或者
    dobuleCount(state){return  state.count*2}
  },
  mutations: {
    add(state,payload:number){
      console.log(state.count)
    }
  },
  actions: {},
  modules: {},
});
// 定义自己的 `useStore` 组合式函数 这里也有了变化
 export function useStore () {
   return baseUseStore(key)//把key导出去了
 }

使用方式 还是和上面的简单方式一样 (只不过是多了访问模块名而已)

  import { useStore } from '../store'
  let store = useStore();  
  console.log(store.state.users.age)

不懂的请留言 欢迎提意见进行改正

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/132567.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CSS3新增的has伪类选择器,让你能轻松选择父元素

文章目录一、语法二、链式操作三、兼容性问题CSS现在新增了一个允许我们选择父元素的伪类&#xff1a;has选择器。可以将其当做父级选择器。 一、语法 选择器1:has(选择器2){} /* 表示选择包含有选择器2的所有的选择器1 比如&#xff1a;*/ div:has(p) {background: black; }…

计算机网络期末考试重点归纳

第 1 章 概述 1. 网络的基本特点 连通性共享性 2. internet 和 Internet 的含义 internetInternet中文名称互连网互联网/因特网名词性质通用名词专用名词名词解释指由多个计算机网络互连而成的计算机网络指当前全球最大的、开放的、由众多网络连接而成的特定互连网&#xff…

电子学会2020年6月青少年软件编程(图形化)等级考试试卷(一级)答案解析

目录 一、单选题&#xff08;共25题&#xff0c;每题2分&#xff0c;共50分&#xff09; 二、判断题&#xff08;共10题&#xff0c;每题2分&#xff0c;共20分&#xff09; 三、编程题&#xff08;共3题&#xff0c;每题10分&#xff0c;共30分&#xff09; 青少年软件编程…

Ubuntu22.04下安装MongoDB(6.0版本)并进行相关数据库操作

前言 昨天用ubuntu22.04安装redis-5.0.5服务&#xff0c;因为版本不兼容&#xff0c;导致问题频发&#xff0c;最终在老师帮助下解决了&#xff0c;这又一次提醒了版本兼容的重要性 MongoDB安装与部署 因为所用ubuntu版本为22.04&#xff0c;所以不能按照老师所给文档进行安…

图书管理系统(Java实现简易版)

目录前言预期效果分析1. book包1.1 Book类1.2 BookList 类2. user包2.1 User类2.2 AdminUser类2.3 NormalUser类3. opera包3.1 IOPeration 接口3.2 AddOperation 类3.3 BrrowOperation 类3.4 DelOperation 类3.5 ExitOperation 类3.6 FindOperation 类3.7 ReturnOperation 类3.…

wikijs-一款wiki系统

2022&#xff0c;别了。 1、介绍 wikijs是一款知识共享wiki&#xff0c;优点是有权限管理系统、支持多人协作共同维护、支持markdown格式、支持评论、风格简洁等等。适合作为个人博客&#xff0c;或者小团队的文档知识库。 效果图&#xff1a; 2、部署流程 2.1、安装dock…

前端 | 装饰你的github profile(github 首页)

1.创建存储库 您可以创建一个与您的 github 帐户名同名的存储库 添加README文件 2.编辑README.md 现在&#xff0c;可以根据自己的喜好修改 repo 中的自述文件&#xff0c;但我在考虑包含哪些信息时查看了其他开发人员的资料。通常包括简短的介绍、使用的技术堆栈和联系方式…

【JAVA进阶】包装类,Arrays类,Lambda表达式

&#x1f4c3;个人主页&#xff1a;个人主页 &#x1f525;系列专栏&#xff1a;JAVASE基础 目录 一、包装类 二、Arrays类 三、Lambda表达式 一、包装类 其实就是8种基本数据类型对应的引用类型。 基本数据类型 引用数据类型 byte Byte short Short int Integer l…

GPU存储器架构

上表表述了各种存储器的各种特性。作用范围栏定义了程序的哪个部分能使用该存储器。而生存期定义了该存储器中的数据对程序可见的时间。除此之外&#xff0c;Ll和L2缓存也可以用于GPU程序以便更快地访问存储器。 总之&#xff0c;所有线程都有一个寄存器堆&#xff0c;它是最快…

Vue 页面渲染的流程

前言 在 Vue 核心中除了响应式原理外&#xff0c;视图渲染也是重中之重。我们都知道每次更新数据&#xff0c;都会走视图渲染的逻辑&#xff0c;而这当中牵扯的逻辑也是十分繁琐。 本文主要解析的是初始化视图渲染流程&#xff0c;你将会了解到从挂载组件开始&#xff0c;Vue…

2022年度总结与2023未来规划

这里写自定义目录标题2022年计划完成情况原始计划生活方面技术方面完成情况2023年规划初步安排技术方面生活方面2022年计划完成情况 原始计划 生活方面 健身&#xff08;体重增到145&#xff09;争取发展一个新的爱好&#xff08;游泳、拳击&#xff09;会做6个菜&#xff0c…

卷径计算详解(通过卷绕的膜长和膜厚进行计算)

有关卷绕+张力控制可以参看专栏的系列文章,文章链接如下: 变频器简单张力控制(线缆收放卷应用)_RXXW_Dor的博客-CSDN博客_收放卷应用张力控制的开闭环算法,可以查看专栏的其它文章,链接地址如下:PLC张力控制(开环闭环算法分析)_RXXW_Dor的博客-CSDN博客。https://blo…

元旦绚丽3D烟花代码

每天就是元旦了&#xff0c;新年怎么能少得了烟花呢&#xff1f;虽然绝大部分地区禁止燃放烟花&#xff0c;但该欣赏的烟花还是要欣赏滴~~ 最近整理文件&#xff0c;找到了一份烟花代码&#xff0c;3D特效&#xff0c;今天分享给大家&#xff0c;希望大家喜欢。 链接: https://…

深入浅出索引(下)

在上一篇文章中,我和你介绍了 InnoDB 索引的数据结构模型,今天我们再继续聊聊跟 MySQL 索引有关的概念。 在开始这篇文章之前,我们先来看一下这个问题: 在下面这个表 T 中,如果我执行 select * from T where k between 3 and 5,需要执行几次树的搜索操作,会扫描多少行…

搜索二叉树及其实现(迭代和递归实现)

二叉搜索树 二叉树搜索树又叫二叉排序树&#xff0c;它还有可能为一个空树。搜索二叉树的性质有 若他的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点。若他的右子树不为空&#xff0c;则右子树上所有节点的值都大于根节点。他的左右子树均为二叉搜索树 迭代…

微信小程序登录鉴权

小程序使用微信登录态进行授权登录 1、调用wx.login生成code wx.login()这个API的作用为当前用户生成一个临时的登录凭证&#xff0c;这个临时登录凭证有效期只有5分钟。拿到登录凭证后就可进行下一步操作&#xff0c;获取openid和session_key Taro.login().then((res) > …

Java:基于注解对类实例字段进行通用校验

前言 后台服务处理前端的请求时&#xff0c;会有这样的一种需求&#xff0c;即校验请求中的参数是否符合校验规则。校验参数是否符合的一种方法是&#xff0c;罗列请求参数&#xff0c;基于校验规则一个一个的校验参数&#xff0c;如果存在不符合的&#xff0c;就返回字段值不…

第20章 离差

第20章 离差 20.1 马尔可夫定理 一般来说&#xff0c;马尔可夫定理能够粗略估计一个随机变量的值等于一个比它的平均值大得多的值的概率。 例子&#xff1a;IQ的平均值是100。我们可以得到&#xff1a;最多1/3的人IQ可以达到300及以上&#xff0c;因为如果IQ>300的人超过…

基于情感词典、k-NN、Bayes、最大熵、SVM的情感极性分析及对比,含数据集

完整代码下载地址&#xff1a;基于情感词典、k-NN、Bayes、最大熵、SVM的情感极性分析及对比&#xff0c;含数据集 1、预处理 &#xff08;1&#xff09;、特征提取 对应文件&#xff1a;feature_extraction.py 最后结果&#xff1a; X^2值前几名的词语。能看出这些词都是一…

喜报丨武汉无名创新科技有限公司荣获国家“高新技术企业”证书,将助力高校科研与竞赛无人机产业加速发展!

2022年11月03日&#xff0c;高新技术企业认定管理官网公告了湖北省2022年第一批通过认定的高新技术企业名单&#xff0c;武汉无名创新科技有限公司&#xff08;简称“无名创新”&#xff09;榜上有名&#xff0c;证书编号为GR202242000480。“国家高新技术企业”认定是对无名创…