简介
在本实验中,我们将探讨在 JavaScript 中否定谓词函数的概念。我们将学习如何创建一个高阶函数,该函数接受一个谓词函数并返回一个新函数,该新函数会否定原始函数的输出。通过实际示例,我们将了解此技术在过滤数组或验证输入时如何发挥作用。
This tutorial is from open-source community. Access the source code
💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版
在本实验中,我们将探讨在 JavaScript 中否定谓词函数的概念。我们将学习如何创建一个高阶函数,该函数接受一个谓词函数并返回一个新函数,该新函数会否定原始函数的输出。通过实际示例,我们将了解此技术在过滤数组或验证输入时如何发挥作用。
要在 JavaScript 中否定一个谓词函数,你可以使用 !
运算符。为此,你可以创建一个名为 negate
的高阶函数,它接受一个谓词函数,并将 !
运算符应用于该函数及其参数。以下是实现 negate
的示例:
const negate =
(func) =>
(...args) =>
!func(...args);
然后,你可以使用 negate
来否定任何谓词函数。以下是如何使用 negate
从数组中过滤出偶数的示例:
const isEven = (n) => n % 2 === 0;
const isOdd = negate(isEven);
[1, 2, 3, 4, 5, 6].filter(isOdd); // [ 1, 3, 5 ]
在这个示例中,isEven
是一个检查数字是否为偶数的谓词函数。然后,我们使用 negate
创建一个名为 isOdd
的新谓词函数,通过否定 isEven
来检查数字是否为奇数。最后,我们将 isOdd
与 filter
方法一起使用,从数组中过滤出偶数。
恭喜你!你已经完成了否定谓词实验。你可以在 LabEx 中练习更多实验来提升你的技能。