转载请注明 本文出自: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. Phoenix与Squirrel 是什么?

    不多说,直接上干货! 前言 Phoenix是HBase的开源SQL引擎. squirrel是windows上Phoneix可视化工具.  Phoenix的官网 http://phoenix.apach ...

  2. sql 系统函数

    --查看表备注SELECT a.column_id AS No, a.name AS 列名, isnull(g.[value],'-') AS 说明 FROM sys.columns a left j ...

  3. 5.26 Quartz任务调度图解2

  4. SDOI 2018 round2游记

    Day 0 早上起来从北京到济南 住宿环境不错 不过比赛环境怎么这么low啊 而且我在最偏僻的考场中最偏僻的角落里 身边居然是个妹子?! Day1 7:40到的考试地点 发现诸位大佬已经打完板子了or ...

  5. RecyclerView 通用 Adapter

    先看使用方法

  6. RadioButtonList绑定后台的数据。

    在前台,放置一个 <td style="width: 650px;"><asp:RadioButtonList ID="RadioButtonList2 ...

  7. 【SQL】INTERVAL YEAR TO MONTH 和 INTERVAL DAY TO SECOND

    INTERVAL YEAR TO MONTH: 作为年和月的时间间隔存储 INTERVAL DAY TO SECOND: 作为天.小时.分和秒的时间间隔存储(DAY,HOUR,MINUTE,SECON ...

  8. Linux 之常用操作指令详解

    1. 查看当做操作目录位置 > pwd 2. 查看(当前)目录里边的文件内容 > ls //list > ls -l 或ll //显示文件的详细信息 > ls -al //al ...

  9. marquee标签弹幕效果

    播放个视频的时候看到很有趣的弹幕,想着前端能不能做个弹幕效果.弹幕是滚动的,所以首先想到了<marquee>标签.但事实上,<marquee>标签不是w3c的标准,只是主流的浏 ...

  10. sqlserver 和MySQL的一些函数的区别

    相同的表数据在sqlserver和MySQL中使用各自的函数得到相同的结果,如下表 drop table tb;create table tb(id int, value1 varchar(10), ...