原始类型

ECMAScript5原始类型primitive type),即UndefinedNullBooleanNumberStringECMA-262把术语类型type定 义为值的一个集合,每种原始类型定义了它包含的值的范围及其字面量表示形式。ECMAScript提供了typeof运算符来判断一个值是否在某种类型的范围内。可以用这种运算符判断一个值是否表示一种原始类型;如果 它是原始类型,还可以判断它表示哪种原始类型。

2.6.1  typeof运算符

typeof运 算符有一个参数,即要检查的变量或值。例如:

对变量或值调用typeof运算符将返回下列值之一:

q  "undefined",如果变量是Undefined型的。

q  "boolean",如果变量是Boolean型的。

q  "number",如果变量是Number型的。

q  "string",如果变量是String型的。

q  "object",如果变量是一种引用类型或Null类型的。

你也许会问,为什么typeof运算符对于null值会返回"object"。这实际上是JavaScript最初实现中的一个错误,然后被ECMAScript沿用了。现在,null被认为是对象的占位符,从而解释了这一矛盾,但从技术上来说,它仍然是原始值。

2.6.2  Undefined类型

如前所述,Undefined类型只有一个值,即undefined。当声明的变量未初始化时,该变量的默认值是undefined

前面一行代码声明变量oTemp,没有初始值。该变量将被赋予值undefined,即Undefined类型的字面 量。可以用下面的代码段测试该变量的值是否等于undefined

这段代码将显示"true",说明这两个值确实相等。还可以用typeof运算符显示该变量的值是undefined

注意,值undefined并不同于未定义的值。但是,typeof运算符并不真正区分这两种值。考虑下面的代码:

前面的代码对两个变量输出的都是"undefined",即使只有变量oTemp2是未定义的。如果不用typeof运算符,就对oTemp2使用其他运算符,这将引起错误,因为那些运算符只能用于已定义的变量。例如,下面的代码将引发错误:

当函数无明确返回值时,返回的也是值undefined,如下所示:

2.6.3  Null类型

另一种只有一个值的类型是Null,它只有一个专用值null,即它的字面量。值undefined实际上是从值null派生来的,因此ECMAScript把它们定义为相等的。

尽管这两个值相等,但它们的含义不同。undefined是声明了变量但未对其初始化时赋予该变量的值,null则用于表示尚未存在的对象(在讨论typeof运算符时,简单地介绍过这一点)。如果函数或方法要返回的是对象,那么找不到该对象时,返回的通常是null

2.6.4  Boolean类型

Boolean类型是ECMAScript中最常用的类型之一。它有两个值truefalse(即两个Boolean字面量)。即使false不等于00也可以在必要时被转换成false,这样在Boolean语句中使用两者都是安全的。

2.6.5  Number类型

ECMA-262中定义的最特殊的类型是Number型。这种类型既可以表示32位的整数,还可以表示64位的浮点数。直接输入的(而不是从另一个变量访问的)任何数字都被看作Number型的字面量。例如,下面的代码声 明了存放整数值的变量,它的值由字面量55定义:

整数也可以被表示为八进制(以8为底)或十六进制(以16为底)的字面量。八进制字面量的首数字 必须是0,其后的 数字可以是任何八进制数字(07), 如下面代码所示:

要创建十六进制的字面量,首位数字必须为0,其后接字母x,然后是任意的十六进制数字(09AF)。这些字母可以是大写的,也可以是小写 的。例如:

尽管所有整数都可 表示为八进制或十六进制的字面量但所有数**算返回的都 是十进制结果。

要定义浮点值,必须包括小数点和小数点后的 一位数字(例如,用1.0而不是1)。 这被看作浮点数字面量。例如:

浮点字面量的有趣之处在于,用它进行计算前,真正存储的是字符串。

对于非常大或非常小的数,可以用科学记数法 表示浮点值。采用科学记数法,可以把一个数表示为数字(包括十进制数字)加e(或E),后面加乘以10的倍数。不明白?下面是一个示例:

该符号表示的是数31250000。把科学记数法转化成计算 式就可以得到该值:3.125×107,即等于3.125×10×10×10×10×10×10×10

也可用科学记数法表示非常小的数,例如0.00000000000000003可 以表示为3-e17(这里,10被升到-17次幂,意味着需要被1017次)。ECMAScript默认把具有6个或6个以上前导0的浮点数转换成科学记数法。

也可用64IEEE 754形式存储浮点值,这意味着十 进制值最多可以有17个十进制位。17位之后的值将被截去,从而造成一些小的数学误差。

几个特殊值也被定义为Number类型的。前两个是Number.MAX_VALUENumber.MIN_ VALUE,它们定义了Number值集合的外边界。所有ECMAScript数都必须在这两个值之间。不过计算生成的数值结果可以不落在这两个数之间。

当计算生成的数大于Number.MAX_VALUE时,它将被赋予值Number.POSITIVE_INFINITY,意味着不再有数字值。同样,生成的数值小于Number.MIN_VALUE的计算也会被赋予值Number.NEGATIVE_INFINITY,也意味着不再有数字值。如果计算返回的是无穷大值,那么生成的结果不能再用于其他计算。

事实上,有专门的值表示无穷大,(如你所猜测的)即InfinityNumber.POSITIVE_INFINITY的值为InfinityNumber.NEGATIVE_INFINITY的值为-Infinity

由于无穷大数可以是正数也可以是负数,所以可用一个方法判断一个数是否是有穷的(而不是单独测试每个无穷数)。可以对任何数调用isFinit()方法,以确保该数不是无穷大。例如:

最后一个特殊值是NaN,表示非数Not a Number)。NaN是个奇怪的特殊值。一般说来,这种情况发生在类型(StringBoolean等)转换失败时。例如,要把单 词blue转换成 数值就会失败,因为没有与之等价的数值。与无穷大值一样,NaN也不能用于算术计算。NaN的另一个奇特之处在于,它与自身不相等,这意味着下面的代码将返回false

出于这种原因,不推荐使用NaN值本身。函数isNaN()会做得相当好:

2.6.6  String类型

String类型的独特之处在于,它是唯一没有固定大小的原始类型。可以用字符串存储0或更多的Unicode字符,由16位整数表示(Unicode是一种国际字符集,本书后面 将讨论它)。

字符串中每个字符都有特 定的位置,首字符从位置0开始,第二个字符在位置1,依此类推。这意味着字符串中的最后一个字符的位置一定是字符串的长度减1(如图2-2所示)。

字符串字面量是由双引号(")或单引号(')声明的。与Java不同的是,双引号用于声明字符串,单引号用于声明字符。但是,由于ECMAScript没有字符类型,所以可使 用这两种表示法中的任何一种。例如,下面的两行代码都有效:

String类型还包括几种字符字面量,JavaCPerl的开发者应该对此非常熟悉。下表列出了ECMAScript的字符字面量:

   

   

/n

换行

/t

制表符

/b

空格

/r

回车

/f

换页符

//

反斜杠

/'

单引号

/"

双引号

/0nnn

八进制代码nnnn07中的一个八进制数字)表示的字符

/xnn

十六进制代码nnn0F中的一个十六进制数字)表示的字符

/unnnn

十六进制代码nnnnn0F中的一个十六进制数字)表示的Unicode字符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值