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

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

官网写的很清楚: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: {
     users
     },
});
// 定义自己的 `useStore` 组合式函数 这里也有了变化
 export function useStore () {
   return baseUseStore(key)//把key导出去了
 }

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

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

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

相关文章
|
3月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
181 64
|
3月前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
167 60
|
29天前
|
资源调度 JavaScript 前端开发
创建vue3项目步骤以及安装第三方插件步骤【保姆级教程】
这是一篇关于创建Vue项目的详细指南,涵盖从环境搭建到项目部署的全过程。
147 1
|
2月前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
144 3
|
3月前
|
JavaScript 前端开发 API
从Vue 2到Vue 3的演进
从Vue 2到Vue 3的演进
97 17
|
3月前
|
JavaScript 前端开发 API
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
117 17
|
3月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
73 8
|
3月前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
63 1
|
3月前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
79 1
|
3月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。

热门文章

最新文章