JavaScript中的真和假,==和===, 不等
咋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中的真和假,==和===, 不等的更多相关文章
- 真与假与c#,java中的不同之处
/************真与假************/ /*C语言中:真(非0).假(0) * Java.C#中:真(true).假(false) * JavaScript中:真(非0.true. ...
- JavaScript基本概念C - 真与假
真与假 与 c 和 c++ 非常相似, 但与 Java 不同, JS中被认为true或false范围很广.所有对象 (空字符串除外) 和非零数字都被视为 true.空字符串.零.null 和undef ...
- 深入理解JavaScript中的==运算符
原文章地址 在详细介绍图1中的每个部分前,我们来复习一下JS中关于类型的知识: JS中的值有两种类型:基本类型.对象类型. 基本类型包括:Undefined.Null.Boolean.Number和S ...
- javascript 中的 true 或 false
JavaScript中奇葩的假值 通常在以下语句结构中需要判断真假 if分支语句 while循环语句 for里的第二个语句 如 1 2 3 4 5 6 7 if (boo) { // do somet ...
- JavaScript中奇葩的假值
通常在以下语句结构中需要判断真假 if分支语句 while循环语句 for里的第二个语句 如 if (boo) { // do something } while (boo) { // do some ...
- JavaScript中一些你不一定知道的问题(持续更新中。。。。)
一些js的问题与解析 1) ["1","2","3"].map(parseInt);的运行结果是? A.["1",&qu ...
- javascript中typeof与instanceof的区别
JavaScript 中 typeof 和 instanceof 常用来判断一个变量是否为空,或者是什么类型的.但它们之间还是有区别的: typeof typeof 是一个一元运算,放在一个运算数之前 ...
- JavaScript中字符串类型
字符串类型 字符串介绍 这是程序里面使用最为广泛的一-种类型.在JavaScript里面, 可以使用单引号,也可以使用双引号: 字符串这种数据类型非常霸道,它和其他数据类型相加都会被转换后才为字符串类 ...
- Jquery中$(document).ready() 和 JavaScript中的window.onload方法 比较
Jquery中$(document).ready()的作用类似于传统JavaScript中的window.onload方法,不过与window.onload方法还是有区别的. 1.执行时间 win ...
随机推荐
- Luogu-1381 单词背诵
先将n个单词插入哈希表,记录左右端点,每次右端点往后移动,读入一个新的单词并记录下它的哈希值,如果这个单词之前没出现过那么更新\(ans\)和\(minl\),如果左端点的单词出现了不止一次则可以往右 ...
- ML一(概念学习和一般到特殊序)
概念学习和一般到特殊序 Concept Learning and the General-To-Specific Ordering 1 简介 1.1 定义 概念学习(Concept Learning) ...
- 在CentOS安装CMake
http://www.cnblogs.com/mophee/archive/2013/03/19/2969456.html 一.环境描述 1.系统:CentOS 6.4 i386 (min) 2.登录 ...
- oarcle12c打开本地数据库
--显示当前数据库的链接db,是cdb还是pdb. show con_name;--在oracle12c中打开本地数据库,否则本地数据库无法链接alter pluggable database pdb ...
- php:如何使用PHP排序, key为字母+数字的数组(多维数组)
你还在为如何使用PHP排序字母+数字的数组而烦恼吗? 今天有个小伙伴在群里问:如何将一个key为字母+数字的数组按升序排序呢? 举个例子: $test = [ 'n1' => 22423, 'n ...
- Java钉钉开发_异常_01_error code:50002, error message:请求的员工userid不在授权范围内
一.异常原因: 请求的员工不在 应用的可见范围内. 如下图,应用的可见范围只设置为了部分员工.所以导致此异常 二.异常解决 将员工添加进可见范围即可
- JavaUtil_00_资源帖
一.精选工具包 1.Hutool Hutool wiki 二.资源 1.
- java--xml文件读取(SAX)
SAX解析原理: 使用Handler去逐个分析遇到的每一个节点 SAX方式解析步奏: 创建xml解析需要的handler(parser.parse(file,handler)) package com ...
- 【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-> ...
- BZOJ4676 Xor-Mul棋盘
传送门 题目大意懒得写了,题目说的挺明白的了 题解 主要的难点在于异或意义下的最大值和很玄学,但不难发现这道题中让你定义的$D_{i,j}$只参与异或运算,所以我们可以逐位进行讨论.所以我们每一位就只 ...