tips null和undefined的区别

1、undefined类型

  undefined类型只有一个值,即特殊的undefined。在使用var声明变量但未对其加以初始化时,这个变量的值就是undefined,例如:
        var demo;
        alert(demo == undefined);//true
    这个例子只声明了变量,但未进行初始化。它的结果和下面的例子是等价的。
        var demo = undefined;    
        alert(demo == undefined);//true
        注意:字面值undefined主要用于比较
    但是,包含undefined和尚未定义的变量还是不一样的。比如:
        alert(age);    //产生错误age is not defined
    下面我们用typeof操作符来进行下面的操作:
        var test;
        console.log(typeof test);//undefined
        console.log(typeof age);//undefined
    结果表明,对未初始化和未声明的变量执行typeof操作都会返回undefined值。那么可以推导出,当typeof操作符返回undefined时,那么说明被检测的变量还没被声明。
    
    扩展:undefined的类型转换
            console.log(Boolean(undefined));    //false
            console.log(Number(undefined));        //NaN
            console.log(String(undefined));        //undefined
        
        undefined的类型鉴别
            console.log(typeof undefined);        //undefined
            console.log(typeof 'undefined');     //string
    
    注意:undefined不是关键字

2、null类型
    null类型是第二个只有一个值的数据类型。从逻辑角度看,null值表示一个空的指针对象(这个的具体了解见对象的原型),而这也正式使用typeof操作符检测null时,会返回object的原因。
        var a= null;
        console.log(typeof a);//object
        到这里,我们该注意:null是空的对象指针,而[]是空数组,{}是空对象,三者不同。
    扩展:null的类型转换
          console.log(Boolean(null));    //false
          console.log(Number(null));    //0
          console.log(String(null));    //null
      null的类型鉴别
          console.log(typeof null);    //object
          console.log(typeof 'null');    //string
          由于null是null是空的对象指针,我们仅仅用typeof操作符还不行
              console.log(null === null);//true,判断一个值是否为null的最好方法是和null进行恒等比较
              console.log(undefined === null);//false
              console.log('null' === null);//false
              console.log(undefined === undefined);//true
              console.log('undefined' === undefined);//false

  注意:null是关键字

3、理解

  null是一个表示“无”的对象,转为数值时为0;undefined表示“无”的原始值,转化为数值时为NaN。

tips null和undefined的区别的更多相关文章

  1. 字符串怎么换行 || 字符串中使用单引号时应该怎么写 || 保留两位小数 || 数字0在if中的意思是false || 什么情况下会会报undefined || null和undefined的区别 ||

    换行的字符串 "This string\nhas two lines" 字符串中使用单引号时应该怎么写 'You\'re right, it can\'t be a quote' ...

  2. JS中null与undefined的区别

    1.typeof操作符 用来检测变量的数据类型 例:typeof 3.14 //返回number typeof [1,2,3]  //返回object 2.null 只有一个值的特殊类型,表示一个空对 ...

  3. js操作css样式,null和undefined的区别?

    1.js操作css的样式 div.style.width="100px"在div标签内我们添加了一个style属性,并设定了width值.这种写法会给标签带来大量的style属性, ...

  4. 浅谈JS中的!=、== 、!==、===的用法和区别 JS中Null与Undefined的区别 读取XML文件 获取路径的方式 C#中Cookie,Session,Application的用法与区别? c#反射 抽象工厂

    浅谈JS中的!=.== .!==.===的用法和区别   var num = 1;     var str = '1';     var test = 1;     test == num  //tr ...

  5. json,js中typeof用法详细介绍及NaN、 null 及 undefined 的区别

    JSON.parse(jsonstr); //可以将json字符串转换成json对象 JSON.stringify(jsonobj); //可以将json对象转换成json对符串 在js使用中的一个函 ...

  6. null和undefined的区别、数组和伪数组的区别

    null和undefined的区别 undefined: 字面意思是未定义的值,语义是希望表示一个变量最原始的状态,而非人为操作的结果.这种原始状态会在以下四个场景中出现: 声明了一个变量但没有赋值 ...

  7. 浅谈js中null和undefined的区别

    在JS中,null和undefined是经常让人摸不着头脑的东西,尤其是在数据初始化以及处理的过程中,经常稍微不注意,就会让页面在渲染时出现报错,下面来细说下,这两者之间的区别: null 表示一个对 ...

  8. JavaScript null和undefined的区别

    前言 1995年javascript诞生时,最初像Java一样,只设置了null作为表示"无"的值.根据C语言的传统,null被设计成可以自动转为0 但是,javascript的设 ...

  9. JavaScript中Null和Undefined的区别

    Null: null是js中的关键字,表示空值,null可以看作是object的一个特殊的值,如果一个object值为空,表示这个对象不是有效对象. Undefined: undefined不是js中 ...

随机推荐

  1. Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)

    一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)篇 二.本篇目标: l  说说关于cocos2dx手机分辨率适配 l  对前一篇完成的塔防游戏原型进 ...

  2. Objective C for Windows

    You can use Objective C inside the Windows environment. If you follow these steps, it should be work ...

  3. 解决Visual Studio 调试时候不能直接访问.json后缀文件的问题

    Web.config中作如下配置: <system.webServer> <staticContent> <mimeMap fileExtension=".js ...

  4. IOS中的网络编程

    在移动互联网时代,几乎所有应用都需要用到网络下载,比如图片的加载,音乐的下载,安装包的下载,等等,下面我们来看看如何进行下载 一.文件的下载我们用get来请求数据,并对请求的二进制数据进行解析存入文件 ...

  5. [转]说说C#的async和await

    C# 5.0中引入了async 和 await.这两个关键字可以让你更方便的写出异步代码. 看个例子: public class MyClass { public MyClass() { Displa ...

  6. 【css】a:hover 设置上下边框在 ie6 和 ie7 下失效

    前段时间在写样式的时候发现了这个问题,虽然当时就解决了这个 bug 不过还是记录下,以免再次出现这样的问题. demo 代码: <!doctype html> <html lang= ...

  7. 一篇文章,读懂 Netty 的高性能架构之道

    原文 Netty是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持,作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机 ...

  8. saiku 元数据存储分析

    一.介绍 使用saiku的人一定对他的元数据存储都特别感兴趣,特别是有分布式管理需求的项目,更是迫切需要了解.其实它是使用Apache的开源项目Jackrabbit管理文件的! 二.代码跟踪 我也是使 ...

  9. CSS基础(五):定位

    CSS定位机制 CSS 有三种基本的定位机制:相对定位.浮动和绝对定位. 相对定位 相对定位指的是设置为相对定位的元素框会偏移某个距离.元素仍然保持其未定位前的形状,它原本所占的空间仍保留. 如果将b ...

  10. Python测试基础教程

    Python简明教程1-为什么 Pythonhttp://www.automationqa.com/forum.php?mod=viewthread&tid=3674&fromuid= ...