Company logo
  • Empleos
  • Bootcamp
  • Acerca de nosotros
  • Para profesionales
    • Inicio
    • Empleos
    • Cursos y retos
    • Preguntas
    • Profesores
    • Bootcamp
  • Para empresas
    • Inicio
    • Nuestro proceso
    • Planes
    • Pruebas
    • Nómina
    • Blog
    • Comercial
    • Calculadora

0

142
Vistas
How to create a template literal type from object to have keys=values?

I have an object

{
  foo: "bar",
  a: "b",
  roses: "red",
}

I would like to create a template literal which would give me the following possibilities:

"foo=bar" | "a=b" | "roses=red" 

So basically, key=value

What I've done so far is:

type Foo = `${keyof typeof obj}=${typeof obj[keyof typeof obj]}`;

But this give me every possible combination:

"foo=bar" | "foo=b" | "foo=red" | "a=bar" | ...

I feel I need to use a generic but I'm not able to make it work

8 months ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

You can use a self-indexing mapped type:

const obj = {
  foo: "bar",
  a: "b",
  roses: "red",
} as const;

type Foo = {
    [K in keyof typeof obj]: `${K}=${typeof obj[K]}`
}[keyof typeof obj];

This evaluates to:

type Foo = "foo=bar" | "a=b" | "roses=red"

Playground link

8 months ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos