Car*_*ini 3 javascript null undefined typescript
作为参考从 Javascript 中的对象中删除空白属性,如何使其兼容 Typescript?
JS 函数(嵌套对象 | ES10):
function removeEmpty(obj) {
return Object.fromEntries(
Object.entries(obj)
.filter(([_, v]) => v != null)
.map(([k, v]) => [k, v === Object(v) ? removeEmpty(v) : v])
);
}
Run Code Online (Sandbox Code Playgroud)
我已经尝试过Exclude<T, null>,但它不适用于嵌套对象,并且我认为这不是正确的实用程序。
请注意,返回的类型应删除null类型但保留undefined。
示例/预期行为:
type TestType = {
a?: {
b?: {
c: string;
} | null;
z?: {
x: string;
};
} | null;
};
const testObj: TestType = {
a: {
b: null,
z: { x: 'Hi' }
}
};
const resultObj = removeEmpty(testObj);
Run Code Online (Sandbox Code Playgroud)
其中resultObj类型类似于:
type ResultTestTypeExample = {
a?: {
b?: {
c: string;
};
z?: {
x: string;
};
};
};
Run Code Online (Sandbox Code Playgroud)
这对你有用吗?
type ExpandRecursively<T> = T extends object
? T extends infer O ? { [K in keyof O]: ExpandRecursively<O[K]> } : never
: T;
type RemoveNull<T> = ExpandRecursively<{ [K in keyof T]: Exclude<RemoveNull<T[K]>, null> }>
Run Code Online (Sandbox Code Playgroud)
用法:
function removeEmpty<T>(obj: T): RemoveNull<T> {
return Object.fromEntries(
Object.entries(obj)
.filter(([_, v]) => v != null)
.map(([k, v]) => [k, v === Object(v) ? removeEmpty(v) : v])
) as RemoveNull<T>
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4654 次 |
| 最近记录: |