src/types/store.d.ts
/**
* 定义全局的State在 store.d.ts文件中
*/
// 单独的state,导出为单独的module使用
export interface LoginState {
user: object
}
// 全部的state,导出 Vuex.Store时使用
export interface RootState {
login: LoginState
}
// 在 src/store.index.ts 下使用 RootState
export default new Vuex.Store<RootState>({
modules: {
login
}
})
import { Commit } from ‘vuex‘
import { LoginState } from ‘@/types/store‘ // 引入 store.d.ts 下定义的 LoginState
export interface IUser { // 参数需要的类型定义
email: string
token: string
username: string
bio: string
image: string
}
// 引入全局的
const state: LoginState = {
user: {}
}
const mutations = {
setUser(state: LoginState, user: IUser) {
state.user = user
}
}
const actions = {
setUser(context: { state: LoginState, commit: Commit }, user: IUser) {
context.commit(‘setUser‘, user)
}
}
export default {
namespaced: true,
state,
mutations,
actions
}
src/types/store.d.ts
下定义单独 module
下的 ModuleState(LoginState)
ModuleState(LoginState)
汇总到 RootState
下 供 export default new Vuex.Store<RootState>
使用ParamsType
在store
下的各自module
下(IUser) 参照上面的demo原文:https://www.cnblogs.com/leslie1943/p/13466943.html