Вроде бы ж не in , а is keyof
Тогда нужен не Enum, а тип, допускающий, что могут быть и другие ключи. type TestOrSomething = Test & Record<string, any> или даже { d: any } если заранее известно, что других ключей не будет
А такой вариант? const getTest = (v: string): Test | undefined => Test[v as Test];
Нужно с енаом, к сожаленибю
Ну да, походу только кастовать..
ts это или вы ему говорите, что там такой тип, или он автоматом это получает из других типов. У вас енам с предустановленными значениями, а не объект с динамическими, значит тайп скрипт автоматически проверит есть такое значение или нет, и автоматически он по любому найдет, и на вашу реализацию даже смотреть не будет)))
А тут то что не так. Почему здесь такая проблема. Раньше это не встречал, но после обновления ТС возникло. Хотя вроде стрикты были включены. Тут же явно написано, что оно может быть undefined.
Та же самая проблема, автоматически тайпскрипт видит, что этого типа там нет (“их там нет”) 🤭 Он даже в ошибке это говорит) т.е. он еще на этапе распарсивания data[Test.c] ругается, а на undefined он будет смотреть потом, когда проверит возвращаемый тип
Да, но как это проверить? Много где в коде все поломалось после обновы
Так нельзя. Объявляя enum, вы говорите, что в типе нет и не может быть других данных, а потом проверяете на наличие чего-то ещё.
Понял. В будущем коде постараюсь в этих кейсах не использовать, а пока значит кастовать в старом
Обсуждают сегодня