首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Typescript Pick数组未按预期工作

Typescript是一种静态类型的编程语言,它是JavaScript的超集,可以在编译时进行类型检查。Pick是Typescript中的一个内置类型操作符,用于从给定类型中选择指定的属性。

当使用Pick操作符选择一个数组时,它不会按预期工作,因为Pick操作符是用于选择对象的属性,而不是数组的元素。如果要选择数组的元素,可以使用索引类型操作符keyof和映射类型操作符。

以下是解决这个问题的一种方法:

代码语言:txt
复制
type PickArray<T, K extends keyof T> = {
  [P in K]: T[P];
};

const pickArray = <T, K extends keyof T>(arr: T[], keys: K[]): PickArray<T, K>[] => {
  return arr.map(item => {
    const pickedItem: PickArray<T, K> = {} as PickArray<T, K>;
    keys.forEach(key => {
      pickedItem[key] = item[key];
    });
    return pickedItem;
  });
};

// 示例使用
interface Person {
  name: string;
  age: number;
  gender: string;
}

const people: Person[] = [
  { name: 'Alice', age: 25, gender: 'female' },
  { name: 'Bob', age: 30, gender: 'male' },
  { name: 'Charlie', age: 35, gender: 'male' },
];

const pickedPeople = pickArray(people, ['name', 'age']);
console.log(pickedPeople);

上述代码中,我们定义了一个PickArray类型,它接受一个泛型T和一个泛型K,其中T表示数组中元素的类型,K表示要选择的属性的键。然后,我们定义了一个pickArray函数,它接受一个数组和一个属性键的数组,并返回一个新的数组,其中每个元素只包含指定的属性。

在示例中,我们定义了一个Person接口表示人的属性,然后创建了一个包含多个人的数组。我们使用pickArray函数选择了每个人的nameage属性,并将结果打印到控制台上。

这是一个解决Typescript Pick数组未按预期工作的方法,它可以选择数组中的元素的指定属性。对于更复杂的需求,可以根据具体情况进行调整和扩展。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

没有搜到相关的视频

领券