javascript的==和===,以及if(xxx)总结
转载请注明 本文出自:http://blog.csdn.net/nancle
首先说==和===
- 首先说明一个非常特殊的值NaN, typeof(Nav)得到'number',可是NaN不等于不论什么一个值(包含它本身)。推断一个值是不是NaN仅仅能使用isNaN
NaN == NaN //得到 false
NaN === NaN //得到false
isNaN(NaN) //得到true - 然后===也比較简单:
- 等号两边类型和值都相等才返回true
1 === 1 //得到 true
1 === ‘1’//得到false - 对于对象、数组、函数(三者均为对象Object的instance):仅仅有等号两边引用了同一个对象。才返回true。引用不同对象。即使两个对象值相等也返回false。
var a = {test:'test'};
var b = {test:'test'};
var c = a;
a === b //得到false
a === c //得到true - 对于undefined和null:仅仅有两边同一时候为undefined或者同一时候为null时全然相等
undefined === undefined //得到true
null === null //得到true
undefined === null //得到false
- 等号两边类型和值都相等才返回true
- ==略微复杂些:
- 假设等号两边的类型和值相等则返回true
- 假设等号两边类型相等。可是值不相等,则按下面规则比較:
- 假设一个值是数字。还有一个值是字符串,把字符串转换为数字。再用转换后的值进行比較。
1 == '1' //得到true
- 假设一个值为true,将它转化为1,再进行比較。
假设一个值为false,把它转化为0,再进行比較。
true == 1 //得到true
0 == false// 得到true - 假设等号两边都是对象,那么必须引用同一个对象才返回true。假设一个值是对象,还有一个值是数字或字符串。将对象转换成原始类型的值,再进行比較。能够使用对象的toString()方法或valueOf()方法把对象转化成原始类型的值。
JavaScript核心语言的内部类通常先尝试valueOf()方法转换,再尝试toString()方法转换,可是对于Date类。则先运行toString()方法再运行valueOf()方法转换。不属于JavaScript核心语言的对象则能够採用JavaScript实现定义的方式把自身转换成原始数值。
var a = {test:'test'};
var b = {test:'test'};
a.valueOf = function(){return 1};
b.valueOf = function(){return 1};
a == b // 返回false
1 == a //返回true
- 假设一个值是数字。还有一个值是字符串,把字符串转换为数字。再用转换后的值进行比較。
- 对于undefined和null: 等号两边出现随意一个都返回true
undefined == undefined //得到true
null == null //得到true
undefined == null //得到true
然后说明if(xxx):
if(xxx)事实上非常easy,它始终会把xxx的值转换成Boolean(即true或者false); 0,'0',[],null,undefined,NaN转换成Boolean类型都为false。
附:这里说一个非常实用的技巧。在变量前面加两个!! 取反符号。能够把变量强制转换成Boolean类型,这样一来,!!NaN === !!null也得到true,奇妙吧!
javascript的==和===,以及if(xxx)总结的更多相关文章
- W3cshool之JavaScript基础
1. JavaScript 对大小写敏感 名为 "myfunction"的函数和名为 "myFunction" 的函数是两个不同的函数,同样,变量 & ...
- Delphi XE6 通过JavaScript API调用百度地图
参考昨天的内容,有朋友还是问如何调用百度地图,也是,谁让咱都在国内呢,没办法,你懂的. 首先去申请个Key,然后看一下百度JavaScript的第一个例子:http://developer.baidu ...
- JavaScript In OA Framework
原文地址:JavaScript In OA Framework (需FQ) “To be or not to be…… is the question…..!” The famous soliloqu ...
- javascript“命名空间”的费曼输出[原创]
Javascript由于没有命名空间的概念,所以好多的框架或库就用了某些“命名空间”的技巧.在学习作为函数的命名空间时,我翻阅了好多的书本和blog,很多的概念和说明都是要么过于烦杂或过于简单.现在由 ...
- yii2开发后记
h2:first-child, body>h1:first-child, body>h1:first-child+h2, body>h3:first-child, body>h ...
- 批量去除Teleport Pro整站下载文件冗余代码
teleport pro tppabs标签批量删除 teleport pro tppabs标签批量删除 使 用Teleport Pro下载的网页代码中包含了很多垃圾代码,比如下载的html网页代码中会 ...
- js判断当前的访问是手机/电脑
<script type="text/javascript"> var commonURL = 'http://www.xxx.com/'; function mobi ...
- java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单
一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...
- [moka同学摘录]Yii2.0开发初学者必看
想要了解更多YII,PHP方面内容,请关注本博客. 基础总结 1.修改默认控制器/方法 yii默认是site控制器,可以在web.php中设置$config中的'defaultRoute'='xxxx ...
随机推荐
- 【专题】概率期望DP
11.22:保持更新状态:主要发一些相关的题目和个人理解 (P.S.如果觉得简单,可以直接看后面的题目) upd 11.30 更完了 [NO.1] UVA12230 Crossing Rivers ...
- 仿QQ空间长图效果简易版--母亲节感恩
手机网站 母亲节最火的两件事 1.NBA 杜兰特在获MVP催泪致辞献给母亲:她才是真的MVP. 2.QQ空间长图 ------------------------------------------- ...
- Bootstrap栅格系统&媒体查询
bootstrap中几乎所有元素的盒子模型为IE下的盒模型,通俗点说就是box-sizing设置成了:border-box. 栅格系统 媒体查询 媒体查询是非常别致的"有条件的 CSS ...
- Django学习案例一(blog):三. 模型生成数据
1. 什么是模型models Django中以创建类的形式来创建数据表. 在编写代码的过程中,所有对数据库的操作,都是对类和类的对象进行操作. ORM对象关系映射(Object relation ma ...
- Android自定义开机和关机动画
Android自定义开机和关机动画 Android在开机的过程中,会经历三张图片,关于静态图的修改在我的这篇文章中有介绍到: Android开机图片替换 现在要介绍的是怎么用动画替换静态图片.开/关机 ...
- 判断input或者div.span等标签是否存在
//用jQuery检查某个元素在网页上是否存在时,应该根据获取元素的长度来判断,代码如下 if($("#email"+i).length > 0){//判断input是否存在 ...
- mysql中int、bigint、smallint 和 tinyint的区别与长度
各种整形,总结留作参考. bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字).存储大小为 ...
- Apache2.2 启动和停止命令
1.启动:net start apache2.2 2.停止:net stop apache2.2
- Redis好在哪?
Redis免费入门教程:阿里云大学—开发者课堂 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. Redis ...
- eas之日期选择控件
初始化打印控件KDPrinter ctrlPrinter = new KDPrinter(); 增加列 // 指定插入位置table.addColumn(index);// 插入到最后table.ad ...