[Typescript] Excess Properties in Functions
interface User {
id: number;
name: string;
}
const users = [
{
name: 'Waqas',
},
{
name: 'Zain',
},
];
const usersWithIds: User[] = users.map((user, index) => ({
...user,
id: index,
// @ts-expect-error
age: 30,
}));
The above code doesn't emit any compiler error from Typescript, but the age
is not expected in User
type, we need to figure out a way to let Typescript to report error for it.
Solution:
interface User {
id: number;
name: string;
}
const users = [
{
name: 'Waqas',
},
{
name: 'Zain',
},
];
function transformUser(user: { name: string }, index: number): User {
return {
...user,
id: index,
// @ts-expect-error
age: 30,
};
}
const usersWithIds = users.map(transformUser);
Another way:
interface User {
id: number;
name: string;
}
const users = [
{
name: 'Waqas',
},
{
name: 'Zain',
},
];
const usersWithIds = users.map((user, index) => ({
...user,
id: index,
// @ts-expect-error
age: 30
} satisfies User));
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2023-08-01 [Docker] Docker Node.js project tips
2023-08-01 [React] forwardRef typescript
2022-08-01 [Typescript] Class - Param properties
2018-08-01 [Mini Programe] Upload Images
2018-08-01 [JavaEE] Data Validation
2016-08-01 [React Native] Build a Github Repositories component
2014-08-01 [Backbone]5. Model & View, toggle between Models and Views -- 2