js中关于if(xx)和 a==b

if判断

在js中一般不使用if(变量)的方式使用if条件语句,容易产生你所不希望的结果,
先来看看如下的代码

if ("hello") {
    console.log("hello")
}//1
if ("") {
    console.log('empty')
}//2
if (" ") {
    console.log('blank')
}//3

看了上面三个if语句,你能准确得出结果吗?
来看第一个,if('hello')if(" ")和if从直观上应该是输出结果,if("")应该是不输出结果的,经过测试的却如此。那么再看下面的代码

if ([0]) {
    console.log('array')
}

if('0.00'){
  console.log('0.00')
}

这里就比较模糊了,按理说还是输出结果的,但是没有特别确定,经过测试都输除了结果。

那么上面的if是按照什么原理的呢?
js是把括号里面的变量转化成布尔类型的变量然后进行判断的。

类型 结果
Undefined false
Null false
Boolean 直接判断
String 除了空字符串为false,其他为true
Number 除了0,-0,+0,Nan其他为 true
Object true

记住这些以后看到if(变量)就可以轻松的得到结果了,当然最好还是避免使用判断语句中直接使用变量的情况。

相等运算符 ==

下面来看看不严格相等符号
==在比较相同类型的数据时,和===是一样的结果。不同的数据类型===会直接返回false,而==则不一样,有如下的规则

  • 原始类型的值
    原始类型的数据会转换成数值类型再进行比较。
  • 对象与原始类型值比较
    对象(这里指广义的对象,包括数组和函数)与原始类型的值比较时,对象转化成原始类型的值,再进行比较。
  • undefined 和 null
    undefined和null与其他类型的值比较时,结果都为false,它们互相比较时结果为true。

相等运算符的缺点:
相等运算符隐藏的类型转换,会带来一些违反直觉的结果。

0 == ''             // true
0 == '0'            // true

2 == true           // false
2 == false          // false

false == 'false'    // false
false == '0'        // true

false == undefined  // false
false == null       // false
null == undefined   // true

' \t\r\n ' == 0     // true

所以日常最好使用严格相等运算符===。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 9,698评论 0 13
  • 运算符是处理数据的基本方法,用来从现有的值得到新的值。JavaScript 提供了多种运算符,本章逐一介绍这些运算...
    许先生__阅读 3,751评论 0 3
  • 一、Java 简介 Java是由Sun Microsystems公司于1995年5月推出的Java面向对象程序设计...
    子非鱼_t_阅读 9,812评论 1 44
  • ————岂曰无衣
    文恨阅读 803评论 0 0
  • 经常会感叹,这个人如此优秀居然还这么努力,再想想自己不禁黯然神伤,自己整天无所事事的样子,真是让人心疼,我们总是会...
    生活即道阅读 3,658评论 0 2