我应该如何解释在Typescript中检查代码类型
我很困惑,我是否可以用它来解释这个问题我应该如何解释在Typescript中检查代码类型,typescript,Typescript,我很困惑,我是否可以用它来解释这个问题 interface IUser { name: string; age: number; } function fn(user: IUser): void {} const user = { name: 'bob', age: 18, height: 188 }; fn({ name: 'bob', age: 18, height: 188 }); // error! fn(user); // no error 错误来自Typescript,
interface IUser {
name: string;
age: number;
}
function fn(user: IUser): void {}
const user = { name: 'bob', age: 18, height: 188 };
fn({ name: 'bob', age: 18, height: 188 }); // error!
fn(user); // no error
错误来自Typescript,它告诉您正在那里创建一个新对象,其中包含不需要的数据 当您使用一个已经创建的对象来实现您的接口,但它有另一个值时,它可能是一个子类或扩展您的接口的另一个接口,因此有额外的项是您想要的行为
另一方面,使用额外参数动态创建新对象是一种迹象,表明您认为
fn
需要不同类型的对象才能正常工作。错误源于Typescript告诉您正在使用不需要的数据创建新对象
当您使用一个已经创建的对象来实现您的接口,但它有另一个值时,它可能是一个子类或扩展您的接口的另一个接口,因此有额外的项是您想要的行为
另一方面,使用额外参数动态创建新对象表明您认为
fn
需要不同类型的对象才能正常工作。请参阅@ShivamSingla谢谢!见@ShivamSingla谢谢!谢谢回复,我得到了一些有用的信息。谢谢回复,我得到了一些有用的信息。