首页 >web前端 >js教程 >JavaScript 快速入门:糟糕的比较

JavaScript 快速入门:糟糕的比较

Patricia Arquette
Patricia Arquette原创
2024-10-17 06:18:29768浏览

JavaScript Quick Bits: Bad Comparisons

小虫子可能会从意想不到的地方爬进来。错误的值可能会使您的条件逻辑以意想不到的方式失败。让我们快速看一下严重不平等带来的令人头痛的问题。

基础知识

这些功能并不相同。它们大部分相同,但有一个非常具体的区别。你看到了吗?

const one = (a) => a > 10;
const two = (a) => !(a <= 10);

每当我们使用 undefined 或 NaN 执行不等式检查时,结果都是 false。如果我们不明确检查边缘情况,两次“等效”检查可能会返回不同的答案。

它是如何发生的

if (!(value <= 10)) {
  // ...

如果您遇到该代码,您可能会毫不犹豫地将其更改为 if (a > 10) { 。

  • 更短了。
  • 更容易阅读。
  • 对于所有正常值它们是相同的。

为什么这很重要

但是我们并不总能得到正常值。这可能是对您的代码的重大更改。这可能会导致非常难以排除缺陷。这个简单的代码中没有任何内容表明我们可能会遇到“坏”值,因此您可能会完全错过它。

类型安全也无法解决这个问题,因为 NaN 是一个数字......它只是一个

结论

如果您在代码中遇到这样的奇怪情况,请问问自己,如果您更改错误值,会发生什么情况。希望您的代码可以防止您获得错误的值并执行错误的数学运算,但对这些更改采取一点防御措施可以为您未来的自己省去很多麻烦。

在这种情况下,通常最好对错误值进行显式检查。这些可以向其他开发人员清楚地传达可能的输入和预期结果。

if (Number.isNaN(value) || value > 10) {
  // ...

以上是JavaScript 快速入门:糟糕的比较的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn