!=和!==的区别

在JavaScript中,!=!== 是两种不同类型的比较运算符,它们之间的主要区别在于它们如何处理比较中的类型转换(也称为“强制类型转换”或“宽松比较”与“严格比较”)。

  1. !=(宽松比较):

    • 如果两个操作数的类型不同,它会尝试将它们转换为相同的类型,然后再进行比较。
    • 例如,5 != '5' 在宽松比较下会返回 false,因为字符串 '5' 会被转换为数字 5,然后两个 5 进行比较,结果是相等的。
    • 同样地,null != undefined 在宽松比较下也会返回 false,因为 nullundefined 在比较前会被转换为相同的类型(通常是 Number),但在这个特定情况下,它们都转换为 NaN,而 NaN 与任何值(包括它自身)的比较结果都是 false
  2. !==(严格比较):

    • 它不仅比较两个操作数的值,还比较它们的类型。
    • 如果两个操作数的类型不同,或者它们的值不同,那么严格比较的结果就是 true
    • 例如,5 !== '5' 在严格比较下会返回 true,因为尽管它们的值看起来相同,但一个是数字类型,另一个是字符串类型。
    • 同样地,null !== undefined 在严格比较下也会返回 true,因为它们的类型不同。

在你给出的代码示例中:

if (newValue != value) {
    updater[key] = data[key]
}

if (newValue !== value) {
    updater[key] = data[key]
}

如果 newValuevalue 的类型不同但值可以相互转换(例如一个是数字 5,另一个是字符串 '5'),那么第一个 if 语句(使用 !=)中的条件会评估为 false,而第二个 if 语句(使用 !==)中的条件会评估为 true

因此,选择使用 != 还是 !== 取决于你的具体需求。如果你只关心值是否相等(不考虑类型),那么可以使用 !=。但如果你同时关心值和类型是否都相等,那么应该使用 !==

对于一个为数值的字段,值为0或者为空,在这两种写法下,是true还是false?

对于一个数值字段,如果字段的值为 0 或者为空(在JavaScript中,空值通常表示为 nullundefined),那么这两种比较运算符(!=!==)的行为会有所不同。

1. 当字段值为 0 时:

  • 使用 !=(宽松比较):

    • 如果 newValue0,而 value 也是 0,则 newValue != value 会返回 false,因为它们的值和类型都相同。
    • 如果 newValue0,而 value 是其他数值(非0),则 newValue != value 会返回 true
    • 如果 newValue0,而 valuenullundefined,则 newValue != value 也会返回 true,因为JavaScript在宽松比较时会将 nullundefined 转换为 Number 类型(在这种情况下,转换为 NaN),而 0 != NaN 返回 true
  • 使用 !==(严格比较):

    • 如果 newValue0,而 value 也是 0,但它们的类型相同(都是 Number),则 newValue !== value 会返回 false
    • 如果 newValue0,而 value 是其他类型(如 nullundefined 或字符串),则 newValue !== value 会返回 true,因为它们的类型不同。

2. 当字段值为空(nullundefined)时:

  • 使用 !=(宽松比较):

    • 如果 newValuenullundefined,而 value 也是 nullundefined(且类型相同),则 newValue != value 会返回 false
    • 如果 newValuenullundefined,而 value 是其他任何值(包括 0),则 newValue != value 会返回 true
  • 使用 !==(严格比较):

    • 如果 newValuenullundefined,而 value 也是相同的 nullundefined(且类型相同),则 newValue !== value 会返回 false
    • 如果 newValuenullundefined,而 value 是其他任何值(包括 0),则无论 value 的值是什么,newValue !== value 都会返回 true,因为它们的类型不同。

结论:

  • 对于数值字段,如果字段的值为 0,并且你只想检查值是否相等(不考虑类型),那么使用 !=value === 0 都可以。但如果要考虑类型,你应该使用 !==
  • 如果字段的值为空(nullundefined),并且你想要检查它是否为空,那么使用 ===!== 更为明确,因为 ==(宽松等于)在处理 nullundefined 时可能会产生意外的结果。

最佳实践是尽可能使用 ===!== 来进行比较,以避免由于隐式类型转换而导致的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/730150.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

智能猫砂盆效果这么惊艳吗?绝对不踩雷的智能猫砂盆合集来啦

身为一个铲屎官,我深受“天天铲屎”的困扰。想要片刻放松都不行,因为猫砂盆一旦堆积屎尿,尤其在夏天,会迅速发臭,滋生细菌。对猫而言,不清理猫砂盆会让它们感到不适,可能引发疾病或拒绝使用猫砂…

C#唯一进程的处理Winform/WPF

C#唯一进程的处理 1.使用进程(Process)判断winformWPF执行效果: 2.使用互斥体(Metux)实现winformWPF实现效果: 在C#客户端(Winform/WPF)开发过程中,有的情况需要确保程序…

ubuntu22.04安装onlyoffice社区版

安装unbuntu22.04 https://blog.csdn.net/qq_36437991/article/details/135915360 安装onlyoffice sudo apt-get update sudo apt-get upgradepostgresql sudo apt-get install postgresql创建用户和数据库 sudo -i -u postgres psql -c "CREATE USER onlyoffice WIT…

ERP系统品牌大比拼:哪款产品更适合您的企业?

ERP集成了企业的销售、采购、生产、财务等各个环节,实现了资源的优化配置和信息的实时共享。然而,面对市场上琳琅满目的ERP系统产品,许多企业却陷入了选择的困境。 “哪款ERP系统更适合我的企业呢?”这或许是每一位企业决策者心中…

【STM32】SysTick系统滴答定时器

1.SysTick简介 CM4内核的处理和CM3一样,内部都包含了一个SysTick定时器,SysTick 是一个24 位的倒计数定时器,当计到0 时 ,将 从RELOAD 寄存器中自动重装载定时初值。只要不把它在SysTick 控制及状态寄存器中的使能位清除&#xf…

免费ai写作?这三款软件是你的好帮手!

在信息爆炸的今天,自媒体已成为越来越多人展现自我、分享知识的平台。然而,对于许多自媒体创作者来说,写作过程中的灵感枯竭、文笔不畅等问题常常困扰着他们。幸运的是,随着人工智能技术的飞速发展,免费AI写作软件应运…

MyBatisPlus基础学习

一、简介 二、集成MP 三、入门HelloWorld 四、条件构造器EntityWrapper 五、ActiveRecord(活动记录 ) 六、代码生成器 七、插件扩展 八、自定义全局操作 九、公共字段自动填充 十、Oracle主键Sequence 十一、Idea快速开发插件 十二、mybatis-plus实践及架构原理

一文带你全面详细了解安全运维

一、安全运维-网络 1、IP地址相关 IP地址属于网络层地址,用于标识网络中的节点设备。 IP地址由32bit构成,每8bit一组,共占用4个字节。 IP地址由两部分组成,网络位和主机位。 IP地址分类: 类别网络位子网掩码私有地…

【OceanBase诊断调优】 —— DDL时报磁盘不足问题排查

1. 背景 由于在4.x的部分版本中,我们对于一些ddl操作还存在磁盘空间放大问题,本文主要介绍了这一类问题的排查。 2. 问题排查 2.1 整体排查链路 2.2 问题现象 DDL过程中报磁盘空间不足,需要确认是否符合预期,如果是符合预期&a…

告别数据孤岛,Xinstall助力App广告投放实现全渠道归因!

在移动互联网时代,App的推广和运营已成为企业不可或缺的一部分。然而,面对五花八门的广告渠道和繁杂多样的投放方式,如何有效追踪广告和渠道效果,如何甄别和选择流量渠道,成为了众多App开发商和运营者头疼的问题。幸运…

Qt制作程序启动界面类QSplashScreen实例测试详解

目录 一、QSplashScreen的概述 二、QSplashScreen静态图片加载 1、主程序实现 2、mainwindow.h实现 3、mainwindows.cpp实现 三、QSplashScreen动态图片加载 1、主程序实现 2、mainwindow.h实现 3、mainwindows.cpp实现 一、QSplashScreen的概述 QSplashScreen&#x…

LabVIEW电磁超声热态金属在线缺陷检测系统

LabVIEW软件开发的电磁超声热态金属在线缺陷检测系统针对极端高温环境下的金属材料,进行实时、无损的缺陷检测,具有高精度和高可靠性,能够显著提高材料质量控制的效率和准确性。 项目背景 随着工业技术的发展,高温环境下的金属材…

SQL Server入门-SSMS简单使用(2008R2版)-1

环境: win10,SQL Server 2008 R2 参考: SQL Server 新建数据库 - 菜鸟教程 https://www.cainiaoya.com/sqlserver/sql-server-create-db.html 第 2 课:编写 Transact-SQL | Microsoft Learn https://learn.microsoft.com/zh-cn/…

day01-anaconda的安装

Anaconda的安装 参考地址: http://t.csdnimg.cn/mUmSp 安装完毕,可以卸载电脑中的其他python版本,在控制面板中进行卸载。 在命令行指令中输入 pythonPython 3.8.3 (default, Jul 2 2020, 17:30:36) [MSC v.1916 64 bit (AMD64)] :: An…

DSP应用市场的大蛋糕,国产厂商能吃下多少?

DSP是数字信号处理器(Digital Signal Processor)的简称,是一种专门用于高速数学运算的微处理器。DSP能够快速且准确地处理数字信号,同时具备可编程和低功耗等特点,如今在各个领域发挥着越来越重要的作用。 &#xff08…

【Spine学习11】之 战士攻击动作 思路总结(手动调整贝塞尔曲线实现前快后慢)

拿到一份psd文件先观察检查一下图片顺序有没有问题, 重点看一下人物的腿部分层,(如果是大小腿分开画的就网格可打可不打,如果是连在一起画的,那必须打网格) 拿着剑的时候剑和手的层级有没有错位&#xff0c…

六、在Qt下通过PCL在VTK9.3.0下显示自己的pcd点云文件

前几天刚整理好VTK8.2.0,发现我们的项目使用的PCL自带的VTK是9.3.0的,脸黑了快 VTK8.2.0可参考该篇博文:五、在Qt下加载QVTKWidget控件(VTK8.2.0),生成Visual Studio项目,显示点云(C…

02 Shell 编程之条件语句

目录 2.1 条件测试语句 2.1.1 文件测试 2.1.2 整数值比较 2.1.3 字符串比较 2.1.4 逻辑测试 2.2 if 条件语句 2.2.1 if 语句的结构 1. 单分支if 语句 2. 双分支if 语句 3. 多分支if 语句 2.2.2 if 语句应用示例 1. 单分支if 语句应用 2. 双分支if 语句应用 3. 多分支if 语句应…

chrome浏览器 network 显示感叹号(chrome network thinttling is enabled)

chrome浏览器上network出现一个黄色感叹号,鼠标移上去提示chrome network thinttling is enabled,这是因为开启了节流模式,直接把网络模式改为no throttling(有的浏览器为online)就可以了。 ##Tips: 1、n…

《图数据库:理论与实践》书籍销售火爆,二次印刷重磅来袭!

好书共享,就在此刻! 由创邻科技联合电子工业出版社匠心打磨三年,最终成稿的图数据库书籍《图数据库:理论与实践》发行上线后,获得了广泛好评,各平台销量迅速破千,并荣登京东 “数据库图书榜”热…