关闭

undefiined和null

216人阅读 评论(0) 收藏 举报

在数据类型中,undefined和null同属一个家族--原始类型,而且都是一个值!但undefined是变量未初始化时的值,null则是指向一个空对象指针。

undefined在使用var声明变量但未对其初始化时,这个变量的值就是undefined,例如:

var message;

alert(message == undefined);//true

这个例子只声明了变量message,但未对其初始化。结果表明它们是相等的。

不过未对其初始化与尚未定义的变量还是不一样的。

var message;

alert(message);  // undefined

alert(title) //报错

上面例子对尚未声明的变量age就会报一个错误,然而,令人不解的是:对未初始化的变量执行typeof 操作符会返回undefined值,而对未声明的变量执行typeof操作符同样也会返回undefined值,来看下面例子:

var message;
alert(typeof message); // undefined

alert(typeof  title); // undefined

结果表明,对未初始化和未声明的变量执行typeof操作符都返回了undefined值;这个结果又其逻辑上的合理性,因为两个变量本质上不执行真正的操作。

null表示一个空对象指针,所以typeof操作符检测 null 值时会返回“object”,如下

var jeep=null;

alert(typeof car);  // object

实际上,undefined值时派生自null值的,因此它们的相等性即返回true

alert(null == undefined);  //true

这里,位于null和undefined之间的相等操作符总是返回 true,

尽管null和undefined有这样的关系,但它们的用途完全不同,所以无论在什么情况下都没有必要把一个变量的值显示的设置为undefined,可是同样的规则对null却不适用。换句话说,只要意在保存对象的变量还没有真正保存对象,就应该明确地让该变量保存null值。这样做不仅可以体现null作为空对象指针的惯例,而且也有助于进一步区分null和undefined。

0
0
查看评论

IS NULL和=NULL的区别(SQL)

IS NULL是判断某个字段是否为空,为空并不等价于为空字符串或为数字0;  而 =NULL 是判断某个值是否等于 NULL,NULL = NULL和NULL
  • whuqin
  • whuqin
  • 2011-07-13 20:22
  • 6912

NULL,0和'\0'辨析

一直搞不清楚这三者的真正区别,因为有的时候会发现,混用这三种用法,编译器也不会报错,最近读的《征服C指针》这本书中详细地提到了这个问题,我才茅塞顿开,然后试着用自己的语言解读一下。    首先 看一下这三者的定义: NULL: NULL定义在stdio.h中,...
  • acingdreamer
  • acingdreamer
  • 2016-11-09 19:40
  • 6550

oracle null和 ''的区别

SQL> set serveroutput on SQL> declare l_t varchar2(10); 2 begin 3 l_t := ''; 4 if l_t is null then 5 ...
  • dwj19830118
  • dwj19830118
  • 2015-10-29 09:54
  • 381

in,exists和not exists ,not in与null的一些关系记载

In和exist,not in和not exists,其中可能还有null,一直是个很纠结的问题,直到现在自己也不能完全说出两种语句的优劣,使用情况等。 先从查询结果上来讲,上个星期五pub的一篇帖子说到了not in和not exists查询结果不同,记得曾经碰到过这种问题,null的影响,...
  • zhangweixing0
  • zhangweixing0
  • 2012-06-04 15:27
  • 2706

NULL和Empty的区别

标题           SQL   Story摘录(七)————触摸NULL值         ccat(原作)             ...
  • jian704
  • jian704
  • 2007-08-24 13:28
  • 4278

oracle的NULL与''的区别

NULL说明: 1、等价于没有任何值、是未知数。 2、NULL与0、空字符串、空格都不同,NULL没有分配存储空间。 3、对空值做加、减、乘、除等运算操作,结果仍为空。 4、NULL的处理使用NVL函数。 5、比较时使用关键字用“is null”和“is not null”。 6、空值不能被索引,所...
  • ben__ben
  • ben__ben
  • 2013-12-04 17:45
  • 1458

初学者需要注意的undefine和null的区别

JavaScript语言有两个表示"无"的值:undefined和null 相似性:   在JavaScript中,将一个变量赋值为undefined或null,几乎没区别。 var  i = undefined; var ...
  • ywx1996
  • ywx1996
  • 2016-11-14 21:25
  • 204

Java中""与null区别

java中空字符串("")与null的区别: 1、空字符串("")分配了内存。null没有分配内存。 2、""是一个空字符串(String),它在内存中是存在的,它可以使用Object对象中的方法(例如"".toSt...
  • ican87
  • ican87
  • 2014-05-14 13:35
  • 961

mysql null和not null

经常用mysql的人可能会遇到下面几种情况: 1、我字段类型是not null,为什么我可以插入空值 2、为什么not null的效率比null高 3、判断字段不为空的时候,到底要用 select * from table where column 还是要用 select * from...
  • WaiCyuyan
  • WaiCyuyan
  • 2016-10-13 11:38
  • 179

NA 和 NULL

1) NA表示数据集中的该数据遗失、不存在。在针对具有NA的数据集进行函数操作的时候,该NA不会被直接剔除。如x 2) NULL表示未知的状态。它不会在计算之中,如x
  • asongsongsong
  • asongsongsong
  • 2016-03-17 16:46
  • 484
    个人资料
    • 访问:3914次
    • 积分:177
    • 等级:
    • 排名:千里之外
    • 原创:14篇
    • 转载:2篇
    • 译文:0篇
    • 评论:0条
    文章分类