内容简介:Typescript’s ability to deeply-type objects is incredibly handy: it gives you confidence that you’re accessing the right keys on an object and that you’re using those keys as the right types. However, this typing doesn’t come for free: it can add complexit
Typescript’s ability to deeply-type objects is incredibly handy: it gives you confidence that you’re accessing the right keys on an object and that you’re using those keys as the right types. However, this typing doesn’t come for free: it can add complexity to things like change handlers. In this post, we’ll write a deep object change handler that both allows us to specify deep object types and satisfies the Typescript compiler.
A Sample Deep Object Type
Let’s use the following Settings
type as an example. It contains some visual settings about our app and some information about our user.
type Settings = {
display: {
mode: 'light' | 'dark';
};
user: {
name: string;
age: number;
admin: boolean;
};
};
We can then create a sample object that satisfies this type. Let’s use the following example.
const settings: Settings = {
display: {
mode: 'dark',
},
user: {
name: 'Betty',
age: 27,
admin: false,
},
};
Writing a Change Handler
So what if we want a change handler that will change any property two levels deep in this object? The secret lies in the use of Generics. We can specify that our key
is of type K
, where K extends keyof Settings
. Likewise, we can specify that our subkey
is of type S
, where S extends keyof Settings[K]
.
Putting this all together, we get the following change handler!
const updateSettings = <K extends keyof Settings, S extends keyof Settings[K]>(
key: K,
subkey: S,
value: Settings[K][S]
): Settings => {
const newSettings = {
...settings,
[key]: {
...settings[key],
[subkey]: value,
},
};
return newSettings;
};
And there we have it: a framework by which we can update deep types and keep our Typescript compiler happy!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
编程人生(上卷)
[美] Peter Seibel / 图灵社区 / 人民邮电出版社 / 2014-12 / 39.00元
这是一本访谈笔录,记录了当今最具个人魅力的15 位软件先驱的编程生涯。包括Donald Knuth、Jamie Zawinski、Joshua Bloch、Ken Thompson等在内的业界传奇人物,为我们讲述了他们是怎么学习编程的,在编程过程中发现了什么以及他们对未来的看法,并对诸如应该如何设计软件等长久以来一直困扰很多程序员的问题谈了自己的观点。中文版分为上下卷,上卷介绍8位大师。一起来看看 《编程人生(上卷)》 这本书的介绍吧!