export const JSONDiff = <T extends object, K extends keyof T>(p1: T, p2: T, arr: K[]): boolean => {
return JSON.stringify( p1, arr ) !== JSON.stringify( p2, arr );
}
如上面代码所示,需要指定 arr 参数的数据类型,这个数据数据类型是 p1 或者 p2 参数的 key.请问这个改如何指定呢。
JSONDiff(
{name: lantian},
{ age: 16 },
['name', 'age' ]
); // false
JSONDiff(
{name: lantian, age: 16},
{ name: lantian, age: 16},
['name', 'age' ]
); // true
export const JSONDiff = <T extends object, U extends object, K extends (keyof T | keyof U) & (string|number)>(p1: T, p2: U, arr: K[]): boolean => {
return JSON.stringify( p1, arr ) !== JSON.stringify( p2, arr );
}
// 或者这样
export const JSONDiff = <T extends object, U extends object, K extends Exclude<keyof T | keyof U, symbol>>(p1: T, p2: U, arr: K[]): boolean => {
return JSON.stringify( p1, arr ) !== JSON.stringify( p2, arr );
}
定义一个类型 条件1:变量类型是一个字符串。 条件2:变量值不是 get "typescript": "~5.2.2"
有看到过定义比较复杂的泛型类型: 请问下,为何需要定义这么多或的Type呢? 为何不直接定义: 为何需要把这些风马牛不相及的类型(T, Promise, Record)组在一起?
在我的项目中,我希望有一个包含所有类型脚本定义的文件,如下所示: type_defs.tsx: 问题是,当我尝试导出typedefs时,如下所示: 我得到了错误: 正如我在网络中发现的那样,只能对typedef文件进行默认导出,这意味着我必须为每个类型定义准备一个文件,这绝对是荒谬的! 在我看来,不允许typedefs具有多个非默认导出的约束完全是无稽之谈,并且使编码变得多余且难以重用。拥有一个包
假设我创建了一个定义如下的类,并对其调用了方法: 方法有一个名为的参数,它是一个对象。我如何使用类型提示来指定它?我假设您只需输入类名,如,但它不起作用。当我运行它时,我得到一个。我还尝试了新朋友:uuuu main。学生,但它给了我同样的错误。我做错了什么?