![](/img/trans.png)
[英]How to transform response from API request into class instance with `class-transformer` in TypeScript?
[英]How to transform field name using class transformer
我有这个 DTO,当我尝试将其转换为 object 时,它不会转换为我想要的方式。 值转换为 object 但字段名称保持不变。
export class CreatePageGroupsDto {
@IsString()
@Expose()
name: string;
@IsString()
@Expose()
url: string;
@IsEnum(CategoryEnum)
@Expose()
category: CategoryEnum;
@Expose({ name: 'page_view' })
@Transform(({
value = false,
}, ) => {
const pageView: PageView = { stand_alone: value };
return pageView;
} )
stand_alone?: boolean;
}
我有这个 DTO,想把它转换成这样的 object
{
'name': 'string',
'url': 'string',
'category': 'legal',
'page_view': {
stand_alone: false,
},
}
如果您有 dto 实例,并且想要将其转换为 object。 你的代码是对的。
import { Expose, instanceToPlain, Transform } from 'class-transformer';
class CreatePageGroupsDto {
@Expose({ name: 'page_view' })
@Transform(({ value = false }) => {
const pageView = { stand_alone: value };
return pageView;
})
stand_alone?: boolean;
}
const dto = new CreatePageGroupsDto();
dto.stand_alone = false;
console.log(instanceToPlain(dto));
Output:
{ page_view: { stand_alone: false } }
所以我认为你实际上有一个来自 http 请求的普通 object 。 并且您的框架(例如 Nestjs)将请求 object 转换为 dto 实例。 这个过程是plainToInstance
,而不是instanceToPlain
。 您可以尝试像以下代码一样交换page_view
和stand_alone
:
class CreatePageGroupsDto {
@Expose({ name: 'stand_alone' })
@Transform(({ value = false }) => {
const pageView = { stand_alone: value };
return pageView;
})
page_view?: boolean;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.