猿问

[已解决]js中!!有存在的必要么?为什么?

业务背景


  • 浏览`lodash源码

  • 发现了!!这个用法

  • 查了一下,是两次取反的意思

  • 但是没搞懂他存在的必要

示例代码


lodash官方源码
function isObjectLike(value) {  return !!value && typeof value == 'object';
}
我修改后的代码,即直接去掉!!
function isObjectLike(value) {  return value && typeof value == 'object';
}

我的困惑


  • 官方代码的含义

    • 就是取反之后再取反,最后来判断这个变量是否为真

  • 我的代码

    • js会根据数据类型以及变量值,自动判断他为真为假

比如传一个0进去

  • 官方的步骤:

    1. !0 => true

    2. !true => false

  • 我的步骤

    1. 0 => false\

问题


  • 既然结果都一样,那很多大佬写的代码为什么都要这样用呢?肯定不是多此一举吧


HUWWW
浏览 710回答 1
1回答

陪伴而非守候

作用是为了类型转换, 强制转换成布尔值.至于为什么需要. 我来详细说说:function isObjectLike(value) {}我们期望 isObjectLike 的返回值是个 boolean. 但 && 操作的返回值是参与操作的操作数.console.log(1 && 2) // 打印 2console.log(0 && 2) // 打印 0所以如果我们传递给 && 的操作数不是布尔类型的, 那么我么得到的返回值就不是布尔值. 我们看看去掉 !! 会造成怎样的不一致性和bug.function isObjectLike(value) {  return value && typeof value == 'object'; // 去掉 !!} isObjectLike(0) === false // false 什么? 居然不相等?console.log(isObjectLike(0)) // 打印 0你能想象一个叫 isObjectLike 的函数返回值类型却不是 boolean 值吗?
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答