[Typescript] - Dynamic string union types in Typescript
Truong Bui
Published on:
•
Last updated:
Problem
I have a string union type like this:
type Status = 'active' | 'inactive' | 'pending';
but Status can be any string, not only active , inactive , pending . How can I define a type that allows any string?
Solution
You can use the following type to allow any string:
type Status = 'active' | 'inactive' | 'pending' | string;
But there is a new problem: we can't use the completion hint anymore
data:image/s3,"s3://crabby-images/b00de/b00de6d8f2cd4fa30163553afaf0e45d7bde3f48" alt=""
To solve this problem, we can use string & {} retain the completion hint
type Status = 'active' | 'inactive' | 'pending' | string & {};
Now, we can use the completion hint again
data:image/s3,"s3://crabby-images/bd9ea/bd9ea3eb2f4a834cb669b54937a9330dc5229884" alt=""
Hope you find this article useful. If you have any questions, please let me know in the comment section below. 👇