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

第二个函数参数的条件类型

是指在 TypeScript 中,可以根据某个条件来确定函数参数的类型。通过使用条件类型,我们可以根据不同的条件来选择不同的类型。

条件类型的语法形式为 T extends U ? X : Y,其中 T 是待检查的类型,U 是条件类型,X 是满足条件时的类型,Y 是不满足条件时的类型。

条件类型可以用于函数参数的类型约束,以根据不同的条件来确定参数的类型。例如,假设我们有一个函数 filter,它接受一个数组和一个条件类型作为参数,并返回符合条件的数组元素:

代码语言:txt
复制
function filter<T, U extends T>(array: T[], condition: (item: T) => item is U): U[] {
  return array.filter(condition);
}

在上述代码中,T 是数组元素的类型,U 是满足条件的类型。condition 参数是一个函数,它接受一个数组元素并返回一个布尔值,用于判断该元素是否符合条件。函数 filter 使用 array.filter 方法来过滤数组元素,并返回符合条件的元素数组。

使用示例:

代码语言:txt
复制
interface Person {
  name: string;
  age: number;
}

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

function isAdult(person: Person): person is Person {
  return person.age >= 18;
}

const adults = filter(people, isAdult);
console.log(adults); // [{ name: 'Alice', age: 25 }, { name: 'Bob', age: 30 }, { name: 'Charlie', age: 35 }]

在上述示例中,我们定义了一个 Person 接口表示人的信息,然后创建了一个包含多个人的数组 people。我们还定义了一个 isAdult 函数,用于判断一个人是否成年。最后,我们调用 filter 函数,传入 people 数组和 isAdult 函数作为参数,返回符合条件的成年人数组。

腾讯云相关产品和产品介绍链接地址:

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

相关·内容

领券