1

1

1

=== 全相等(全部相等)

==  值相等(部分相等)

demo:

var x=0;
undefined
var y=false;
undefined
if(x===y){
console.log("all equal!")
}else if(x==y){
console.log("just value equal!")
}else{
onsole.log("not at all equal!")
}
VM3163:1 just value equal!

1

 null == undefined

 true == 1 == "1"

 false == 0 == ""

 "" + ? == "?" (anything)

 null (value) == 0   (仅当 null + 数字时,成立!)

false+0;// false==0
0
true+0;// true==1
1

0+undefined;
NaN
0+null;// null (value)==0; null==0; false
0
0+NaN;
NaN

1+undefined;
NaN
1+null;// null (value)==1; null==0; false
1
1+NaN;
NaN

NaN+"";
"NaN"
null+"";
"null"
undefined+"";
"undefined"

true+"";
"true"
false+"";
"false"

typeof null;
"object"

typeof NaN;
"number"

typeof undefined;
"undefined"

typeof false;
"boolean"

typeof true;
"boolean"

typeof "";
"string"

typeof 0;
"number"

1

1

1

1

1

x

undefined==null;
true
NaN==null;
false
NaN==undefined;
false
<script>
var a;
if(a==undefined) alert('undefined');//true
if(a==null) alert('null');//true
if(null==NaN) alert('NaN=null');//undefined
if(undefined==NaN) alert('NaN=undefined');//undefined
if(NaN) alert('NaN');//undefined
</script>
null==0;
false
null===0;
false
undefined==0;
false
undefined===0;
false
null==undefined;
true
null===undefined;
false
<script>
var a=null;//(0/false)
var b=undefined;//(false)
var c = 7 ;
alert('undefined+null='+(a+b));//NaN
alert('c+null='+(a+c));//7
alert('c+undefined='+(b+c));//NaN
</script> chrome 测试结果!
个人认为:
null 的取值是(0/false),
undefined 的取值是(false/NaN)。
null==0;
false
null===0;
false
undefined
undefined
undefined==0;
false
undefined===0;
false
null==false;
false
undefined==false;
false
NaN==0;
false
NaN==false;
false
typeof NaN;
"number"
NaN==undefined;
false
typeof null;
"object"
typeof undefined;
"undefined"

false == 0, true == 1

null+false;
0
undefined+false;
NaN
NaN+false;
NaN
NaN+null;
NaN
false+false;
0
false+true;
1
true+true;
2
null+true;
1
undefined+true;
NaN
NaN+true;
NaN
false==0;
true
false===0;
false
true==1;
true
true===1;
false
0==false;
true
0===false;
false
1==true;
true
1===true;
false

1

1

//前端JS blogs:

<!-- http://www.ruanyifeng.com/blog/2014/03/undefined-vs-null.html -->
<!-- http://yanhaijing.com/javascript/2014/01/05/exploring-the-abyss-of-null-and-undefined-in-javascript/ --> //前端JS试题: <!-- https://github.com/N-ZOO/everycode/issues/13 -->
        <script>
var a;
if(a==undefined) alert('undefined');//true
if(a==null) alert('null');//true
if(null==undefined) alert('null==undefined');//true
if(undefined==null) alert('undefined==null');//true
var b =5 ;
alert('b+undefined=||b+null='+(a+b));//NaN
</script>
<script>
var a = null;//(0/false)
var b = undefined;//(false)
var c = 7;
var x;
alert('undefined+null='+(a+b));//NaN
alert('c+null='+(a+c));//7
alert('c+undefined='+(b+c));//NaN
if(x==undefined) alert('undefined');//true
if(x==null) alert('null');//true
if(null==NaN) alert('NaN=null');//undefined
if(undefined==NaN) alert('NaN=undefined');//undefined
if(NaN) alert('NaN');//undefined
</script>

1

1

1

1

1

1

1

1

=== 与 == 区别?

使用 === 判断 两个变量是否完全相等

== 可能会导致,判断错误[code=javascript]

//使用 === 判断 两个变量是否完全相等
//== 可能会导致,判断错误 (undefined == 0)
//false
(null == 0)
//false
(null+1)
//1
(undefined+1)
//NaN
(undefined===null)
//false
(undefined==null)
//true

1

1

1

var a;
undefined
a==null;
true
a==undefined;
true
a===null;
false
a===undefined;
true a=0;
0
a===undefined;
false
a==undefined;
false
a===null;
false
a==null;
false a
0
a+null;
0
a+undefined;
NaN
a+NaN;
NaN a
1
a+NaN;
NaN
a+undefined;
NaN
a+null;
1 null==0;
false
null===0;
false
undefined==0;
false
undefined===0;
false
null==undefined;
true
null===undefined;
false

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

你所不知道的 JS: null , undefined, NaN, true==1=="1",false==0=="",null== undefined的更多相关文章

  1. 你所不知道的js的小知识点(1)

    1.js调试工具 debugger <div class="container"> <h3>debugger语句会产生一个断点,用于调试程序,并没有实际功能 ...

  2. js值----你所不知道的JavaScript系列(6)

    1.数组 在 JavaScript 中,数组可以容纳任何类型的值,可以是字符串.数字.对象(object),甚至是其他数组(多维数组就是通过这种方式来实现的) .----<你所不知道的JavaS ...

  3. js类型----你所不知道的JavaScript系列(5)

    ECMAScirpt 变量有两种不同的数据类型:基本类型,引用类型.也有其他的叫法,比如原始类型和对象类型等. 1.内置类型 JavaScript 有七种内置类型: • 空值(null) • 未定义( ...

  4. 你所不知道的setTimeout

    JavaScript提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成.它们向任务队列添加定时任务.初始接触它的人都觉得好简单 ...

  5. 闭包----你所不知道的JavaScript系列(4)

    一.闭包是什么? · 闭包就是可以使得函数外部的对象能够获取函数内部的信息. · 闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分. · 闭包就 ...

  6. 关于setTimeout()你所不知道的地方,详解setTimeout()

    关于setTimeout()你所不知道的地方,详解setTimeout() 前言:看了这篇文章,1.注意setTimeout引用的是全部变量还是局部变量了,当直接调用外部函数方法时,实际上函数内部的变 ...

  7. JavaScript中你所不知道的Object(二)--Function篇

    上一篇(JavaScript中你所不知道的Object(一))说到,Object对象有大量的内部属性,而其中多数和外部属性的操作有关.最后留了个悬念,就是Boolean.Date.Number.Str ...

  8. Android Context完全解析,你所不知道的Context的各种细节

    Context相信所有的Android开发人员基本上每天都在接触,因为它太常见了.但是这并不代表Context没有什么东西好讲的,实际上Context有太多小的细节并不被大家所关注,那么今天我们就来学 ...

  9. 你所不知道的 CSS 阴影技巧与细节 滚动视差?CSS 不在话下 神奇的选择器 :focus-within 当角色转换为面试官之后 NPOI 教程 - 3.2 打印相关设置 前端XSS相关整理 委托入门案例

    你所不知道的 CSS 阴影技巧与细节   关于 CSS 阴影,之前已经有写过一篇,box-shadow 与 filter:drop-shadow 详解及奇技淫巧,介绍了一些关于 box-shadow  ...

随机推荐

  1. 转 Jmeter测试实践:文件下载接口

    Jmeter测试实践:文件下载接口   一 Jmeter步骤 1.打开jmeter4.0,新建测试计划,添加线程组.根据实际情况配置线程属性. 2.添加HTTP请求.根据接口文档进行配置. Basic ...

  2. 前端面试之HTML5的新变化

    前端面试之HTML5的新变化 H5新增语义化标签 头部标签 <header> :头部标签 <nav> :导航标签 <article> :内容标签 <secti ...

  3. Ubuntu 能ping通DNS 地址 无法解析域名

    ping通qq百度都行,唯独谷歌不行, 主机能够ping通google的dns服务器地址 8.8.8.8,却无法解析域名   $ ping www.google.co.uk ping: unknown ...

  4. ftp协议服务器与tinyhttp服务demo

    https://www.jianshu.com/p/fb9fcb69efc9 ....... https://www.jianshu.com/p/e9a2e0755496 ============== ...

  5. python 9学习 高级特性

    高级特性 掌握了Python的数据类型.  语句      和函数,基本上就可以编写出很多有用的程序了. 比如构造一个1, 3, 5, 7, ..., 99的列表,可以通过循环实现: L = [] n ...

  6. 理解 async/await以及对Generator的优势

    async await 是用来解决异步的,async函数是Generator函数的语法糖使用关键字async来表示,在函数内部使用 await 来表示异步async函数返回一个 Promise 对象, ...

  7. 渗透测试工具-sqlmap

    简单来说:一个用来做sql注入攻击的工具 安装 1,下载sqlmap.zip,下载环境: 打开sqlmap官网https://github.com/sqlmapproject/sqlmap/ :下载p ...

  8. windows提权常用系统漏洞与补丁编号速查对照表

    #Security Bulletin #KB #Description #Operating System CVE-2020-0787 [Windows Background Intelligent ...

  9. 谷粒商城为什么要选择后天管理用vue前后端分离,而商城页面选择Thymeleaf类?

    1.最初使用jsp开发web项目 还记得刚学习Java的时候,自己开发一个web项目,那时候前后端分离还不流行,为了在页面中显示动态数据,最终的形式也就是以动态网页响应用户,Java一种技术jsp,J ...

  10. .NET使用DinkToPdf将HTML转成PDF

    0.介绍 C# .NET Core wrapper for wkhtmltopdf library that uses Webkit engine to convert HTML pages to P ...