转载请注明 本文出自:http://blog.csdn.net/nancle

首先说==和===

  • 首先说明一个非常特殊的值NaN, typeof(Nav)得到'number',可是NaN不等于不论什么一个值(包含它本身)。推断一个值是不是NaN仅仅能使用isNaN
    NaN == NaN //得到 false
    NaN === NaN //得到false
    isNaN(NaN) //得到true
  • 然后===也比較简单:
    1. 等号两边类型和值都相等才返回true
      1 === 1 //得到 true
      1 === ‘1’//得到false
    2. 对于对象、数组、函数(三者均为对象Object的instance):仅仅有等号两边引用了同一个对象。才返回true。引用不同对象。即使两个对象值相等也返回false。
      var a = {test:'test'};
      var b = {test:'test'};
      var c = a;
      a === b //得到false
      a === c //得到true
    3. 对于undefined和null:仅仅有两边同一时候为undefined或者同一时候为null时全然相等
      undefined === undefined //得到true
      null === null //得到true
      undefined === null //得到false
  • ==略微复杂些:
    1. 假设等号两边的类型和值相等则返回true
    2. 假设等号两边类型相等。可是值不相等,则按下面规则比較:
      • 假设一个值是数字。还有一个值是字符串,把字符串转换为数字。再用转换后的值进行比較。

        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
    3. 对于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)总结的更多相关文章

  1. W3cshool之JavaScript基础

        1.  JavaScript 对大小写敏感 名为 "myfunction"的函数和名为 "myFunction" 的函数是两个不同的函数,同样,变量 & ...

  2. Delphi XE6 通过JavaScript API调用百度地图

    参考昨天的内容,有朋友还是问如何调用百度地图,也是,谁让咱都在国内呢,没办法,你懂的. 首先去申请个Key,然后看一下百度JavaScript的第一个例子:http://developer.baidu ...

  3. JavaScript In OA Framework

    原文地址:JavaScript In OA Framework (需FQ) “To be or not to be…… is the question…..!” The famous soliloqu ...

  4. javascript“命名空间”的费曼输出[原创]

    Javascript由于没有命名空间的概念,所以好多的框架或库就用了某些“命名空间”的技巧.在学习作为函数的命名空间时,我翻阅了好多的书本和blog,很多的概念和说明都是要么过于烦杂或过于简单.现在由 ...

  5. yii2开发后记

    h2:first-child, body>h1:first-child, body>h1:first-child+h2, body>h3:first-child, body>h ...

  6. 批量去除Teleport Pro整站下载文件冗余代码

    teleport pro tppabs标签批量删除 teleport pro tppabs标签批量删除 使 用Teleport Pro下载的网页代码中包含了很多垃圾代码,比如下载的html网页代码中会 ...

  7. js判断当前的访问是手机/电脑

    <script type="text/javascript"> var commonURL = 'http://www.xxx.com/'; function mobi ...

  8. java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单

    一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...

  9. [moka同学摘录]Yii2.0开发初学者必看

    想要了解更多YII,PHP方面内容,请关注本博客. 基础总结 1.修改默认控制器/方法 yii默认是site控制器,可以在web.php中设置$config中的'defaultRoute'='xxxx ...

随机推荐

  1. css 继承性和层叠性

    css有两大特性:继承性和层叠性 继承性 面向对象语言都会存在继承的概念,在面向对象语言中,继承的特点:继承了父类的属性和方法.那么我们现在主要研究css,css就是在设置属性的.不会牵扯到方法的层面 ...

  2. Elasticsearch之批量操作bulk

    1.bulk相当于数据库里的bash操作. 2.引入批量操作bulk,提高工作效率,你想啊,一批一批添加与一条一条添加,谁快? 3.bulk API可以帮助我们同时执行多个请求 4.bulk的格式: ...

  3. WebApi中对请求参数和响应内容进行URL编码解码

    项目经测试,发现从IE提交的数据,汉字会变成乱码,实验了网上很多网友说的给ajax加上contentType:"application/x-www-form-urlencoded; char ...

  4. # Nginx设置浏览器缓存

    配置语法 在location或if段里,来写. 格式 expires 30s; expires 30m; expires 2h; expires 30d; (注意:服务器的日期要准确,如果服务器的日期 ...

  5. JavaScript中赋值运算符的使用

    JavaScript中的赋值运算可以分为简单赋值运算和复合赋值运算.简单赋值运算是将赋值运算符(=)右边表达式的值保存到左边的变量中:而复合赋值运算混合了其他操作(例如算术运算操作)和赋值操作.例如: ...

  6. 【VB】时间戳转日期

    DateAdd("s", TimeStamp / 1000, "1970-01-01 00:00:00")

  7. crontab与系统时间不一致

    将线上数据库迁移至虚拟机后,运维没有把时间修改. 在后期把时间修改完成后,在数据库上也要修改修改,但是定时任务的备份时间却不在凌晨4点执行,而是在中午12:10分执行. 原因是修改时间后,需要重启cr ...

  8. Oracle存储过程给变量赋值的方法

    截止到目前我发现有三种方法可以在存储过程中给变量进行赋值: 1.直接法     := 如:v_flag := 0; 2.select into 如:假设变量名为v_flag,select count( ...

  9. Visual Studio UI Automation 学习(二)

    今天恰好有时间,继续学习了一下UI Automation的知识.看了两篇博客,对UI Automation有了进一步的了解. https://blog.csdn.net/qq_37546891/art ...

  10. (转)Bootstrap 之 Metronic 模板的学习之路 - (4)源码分析之脚本部分

    https://segmentfault.com/a/1190000006709967 上篇我们将 body 标签主体部分进行了简单总览,下面看看最后的脚本部门. 页面结尾部分(Javascripts ...