自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(5)
  • 收藏
  • 关注

原创 完整代码完整代码

type GetMutations = Module extends { mutations: infer M } ? M : never type AddPrefix<Prefix, Keys> = ${Prefix & string}/${Keys & string} type GetSubModuleKeys<Module, Key> = Module extends { modules: infer SubModules } ? AddPrefix<Ke

2020-09-16 16:38:58 972

原创 以这个 cart 模块为例,分解一下每个工具类型得到的结果:

cart: { mutations: { add() { }, remove() { } } modules: { subCart: { mutations: { add() { }, } } } }, type GetModuleMutationKeys<Module, Key> = // ‘cart/add’ | ‘cart | remove’ AddPrefix<Key, keyof GetMutations> | // ‘cart/subCart/add’ GetSubMod

2020-09-16 16:38:14 131

原创 cart 模块下还可能有别的 Modules,比如这样:

cart: { mutations: { add() { }, remove() { } } modules: { subCart: { mutations: { add() { }, } } } }, cart: { mutations: { add() { }, remove() { } } modules: { subCart: { mutations: { add() { }, } } } }, cart: { mutations: { add() { }, remove() { } } modul

2020-09-16 16:37:38 100

原创 重头戏在于,我们需要根据 Modules 这个泛型,也就是对应结构:

modules: { cart: { mutations: { add() { }, remove() { } } }, user: { mutations: { login() { } }, modules: { admin: { mutations: { login() { } }, } } } } modules: { cart: { mutations: { add() { }, remove() { } } }, user: { mutations: { login() { } }, module

2020-09-16 16:37:03 66

原创 本文就利用这个特性,简单实现下 Vuex 在 modules 嵌套情况下的 dispatch 字符串类型推断,先看下效果,我们有这样结构的 store:

const store = Vuex({ mutations: { root() {}, }, modules: { cart: { mutations: { add() {}, remove() {}, }, }, user: { mutations: { login() {}, }, modules: { admin: { mutations: { login() {}, }, }, }, }, }, }) const store = Vuex({ mutations: { root() {}, },

2020-09-16 16:36:26 584

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除