咋JS中,下面这些值表示 “假”:

"" (empty string)

0,-0,NaN (invalid number)

null, undefined

false

除了上面这些在“假”值名单中的其他任何值都是“真”的,这里是一些例子:

"hello"

41

true

[],[1,"2",3] (arrays)

{}, {a: 42} (objects)

function foo() { .. } (functions)

== 检测值是否相等的时候,允许发生转换(隐式转换)

===检测值的时候则不允许发生转换, 所以 ===被称为“严格相等”

所以:

== 非严格相等中发生的隐式转换

=== 严格相等

var a = "42";

var b = 42;

a == b  // true

a === b  //false

在JS中,有人不建议使用==,这里有一些总结的规则,来说明何时要避免使用==,何时可以放心的使用==

. 如果比较的两个值可能是 true 或者 false, 避免使用 ==

. 如果比较的两个值是这些特定值(0, "", [] --- 空数组), 避免使用 ==

. 所有其他情况下,你都可以放心使用==, 它不但安全,而且可以提高可读性来简化代码

最大的原则: 如果你对这些值很确定,那使用 == 就是安全的,就可以使用

如果你对这些值不太确定,那就使用 ===

eg: 默认情况下 array数组转为string字符串,就是简单地把所以值通过逗号(,)连接在一起。你可能以为两个拥有相同内容的array是相等的, 但是实际上并不是这样

var a = [1,2,3];

var b = [1,2,3];

var c = "1,2,3";

a == c; //true

b == c; //true

a == b; //false

不等

在JavaScript中,string值也能被用于不等比较,使用的是字母表规则  ("bar" < "foo")

注意与(“==”和“===”) 不同的是, 不等运算符没有 “严格不等” 运算符

var a = 35;
var b = "36";
var c = "37";
a < b; //true
b < c; //true

不同类型的值比较中, 有个特别坑的情况:

var a = 35;
var b = "test";
a < b; //false
a > b; //false
a == b; //false

在 < 和 > 比较中,b被强制转换成"无效的数字"NaN, ES规范中,NaN既不大于也不小于其他任何值.

JavaScript中的真和假,==和===, 不等的更多相关文章

  1. 真与假与c#,java中的不同之处

    /************真与假************/ /*C语言中:真(非0).假(0) * Java.C#中:真(true).假(false) * JavaScript中:真(非0.true. ...

  2. JavaScript基本概念C - 真与假

    真与假 与 c 和 c++ 非常相似, 但与 Java 不同, JS中被认为true或false范围很广.所有对象 (空字符串除外) 和非零数字都被视为 true.空字符串.零.null 和undef ...

  3. 深入理解JavaScript中的==运算符

    原文章地址 在详细介绍图1中的每个部分前,我们来复习一下JS中关于类型的知识: JS中的值有两种类型:基本类型.对象类型. 基本类型包括:Undefined.Null.Boolean.Number和S ...

  4. javascript 中的 true 或 false

    JavaScript中奇葩的假值 通常在以下语句结构中需要判断真假 if分支语句 while循环语句 for里的第二个语句 如 1 2 3 4 5 6 7 if (boo) { // do somet ...

  5. JavaScript中奇葩的假值

    通常在以下语句结构中需要判断真假 if分支语句 while循环语句 for里的第二个语句 如 if (boo) { // do something } while (boo) { // do some ...

  6. JavaScript中一些你不一定知道的问题(持续更新中。。。。)

    一些js的问题与解析 1) ["1","2","3"].map(parseInt);的运行结果是? A.["1",&qu ...

  7. javascript中typeof与instanceof的区别

    JavaScript 中 typeof 和 instanceof 常用来判断一个变量是否为空,或者是什么类型的.但它们之间还是有区别的: typeof typeof 是一个一元运算,放在一个运算数之前 ...

  8. JavaScript中字符串类型

    字符串类型 字符串介绍 这是程序里面使用最为广泛的一-种类型.在JavaScript里面, 可以使用单引号,也可以使用双引号: 字符串这种数据类型非常霸道,它和其他数据类型相加都会被转换后才为字符串类 ...

  9. Jquery中$(document).ready() 和 JavaScript中的window.onload方法 比较

    Jquery中$(document).ready()的作用类似于传统JavaScript中的window.onload方法,不过与window.onload方法还是有区别的.   1.执行时间 win ...

随机推荐

  1. Luogu-1381 单词背诵

    先将n个单词插入哈希表,记录左右端点,每次右端点往后移动,读入一个新的单词并记录下它的哈希值,如果这个单词之前没出现过那么更新\(ans\)和\(minl\),如果左端点的单词出现了不止一次则可以往右 ...

  2. ML一(概念学习和一般到特殊序)

    概念学习和一般到特殊序 Concept Learning and the General-To-Specific Ordering 1 简介 1.1 定义 概念学习(Concept Learning) ...

  3. 在CentOS安装CMake

    http://www.cnblogs.com/mophee/archive/2013/03/19/2969456.html 一.环境描述 1.系统:CentOS 6.4 i386 (min) 2.登录 ...

  4. oarcle12c打开本地数据库

    --显示当前数据库的链接db,是cdb还是pdb. show con_name;--在oracle12c中打开本地数据库,否则本地数据库无法链接alter pluggable database pdb ...

  5. php:如何使用PHP排序, key为字母+数字的数组(多维数组)

    你还在为如何使用PHP排序字母+数字的数组而烦恼吗? 今天有个小伙伴在群里问:如何将一个key为字母+数字的数组按升序排序呢? 举个例子: $test = [ 'n1' => 22423, 'n ...

  6. Java钉钉开发_异常_01_error code:50002, error message:请求的员工userid不在授权范围内

    一.异常原因: 请求的员工不在 应用的可见范围内. 如下图,应用的可见范围只设置为了部分员工.所以导致此异常 二.异常解决 将员工添加进可见范围即可

  7. JavaUtil_00_资源帖

    一.精选工具包 1.Hutool Hutool wiki 二.资源 1.

  8. java--xml文件读取(SAX)

    SAX解析原理: 使用Handler去逐个分析遇到的每一个节点 SAX方式解析步奏: 创建xml解析需要的handler(parser.parse(file,handler)) package com ...

  9. 【leetcode刷题笔记】Reverse Linked List II

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1-> ...

  10. BZOJ4676 Xor-Mul棋盘

    传送门 题目大意懒得写了,题目说的挺明白的了 题解 主要的难点在于异或意义下的最大值和很玄学,但不难发现这道题中让你定义的$D_{i,j}$只参与异或运算,所以我们可以逐位进行讨论.所以我们每一位就只 ...