数据类型
JavaScript是弱类型脚本语言,使用变量之前,无须定义,想使用某个变量时直接使用即可,JavaScript会根据需要自动确定数据类型和进行数据类型的转换,但每个变量还是要确定数据类型的。
JavaScript中数据类型基本数据类型(简单数据类型)和复合数据类型(复杂数据类型)两类,不同大类下面又有自己的小类,如下表:
1、typeof操作符:用来检测给定变量的数据类型
对一个值使用typeof操作符可能返回下列某个字符串之一:
(1)undefined: 值未定义时。
(2)boolean: 值是布尔值时。
(3)string: 值是字符串时。
(4)number: 值是数值时。
(5)object: 值是对象或者null(代表空对象引用)。
(6)function: 值是函数时。
示例:
2、Undefined类型:
该类型只有一个值,即特殊的undefined。在使用var声明变量但未对其加以初始化时,这个变量值就是undefined。(注意值为小写,JS大小写敏感)。示例:
知识扩充:包含undefined值的变量和尚未定义的变量是不一样的。例如:
对于尚未声明的变量,可以使用typeof操作符检测其数据类型。返回值也为:undefined值,和定义后未赋初值的变量一样。即使用一个未定义的变量时没有值,但其类型为Undefined。
建议:定义一个变量时显式地初始化变量。
3、Null类型:
只有一个值,即:null。
null值表示一个空对象(这正是使用typeof检测null值会返回“object”)。如:
4、Boolean类型:
该类型有两个值:true和false。(必须全是小写)
可以将其他值通过Boolean()函数转换为Boolean类型,返回值取决于要转换值的数据类型和实际值。
其他类型转为Boolean类型的规则:
5、Number类型:
包括整数和浮点数值(双精度数值)。
除了常用的十进制外,还可以表示八进制和十六进制。八进制的第一位必须是0,后跟(0~7),十六进制前两位是0x,后跟(0~9及A~F)。八进制和十六进制表示的数值最终将被转换为十进制。
(1)浮点数值:该数值中必须包含一个小数点。
var num1=1.1;
var num2=0.1;
var num3=.1;//有效,但不推荐。如果数值只有小数部分,则可以省略整数部分的0。
(2)数值转换:
2个函数将非数值转换为数值:
A、 parseInt():用于将字符串转换成整数数值。
B、 parseFloat():用于将字符串转换成浮点型数值。
【解释】
parseInt():将字符串转换为整数。
规则:A、它会忽略字符串前面的空格,直至找到第一个非空格字符,如果第一个字符不是数字字符或者负号,则返回NaN。
B、转换空字符串返回NaN。
C、如果第一个字符是数字字符,会接着进行解析,直到完成或者遇到非数字字符。
parseFloat():将一个字符串转成浮点数。
和parseInt基本相同,区别:(1)字符串中的第一个小数点是有效的,第二个小数点是无效的,后面的字符串会被忽略。
“22.34.5” 转成 22.3
(2)始终会忽略前导0(把前导0直接去掉),十六进制数始终被转成0,只解析十进制数,所以没有第二个参数。即只能转成十进制
(3)字符串中没有小数点或小数点后边全是0,则该函数返回整数。
6、String类型:
表示由0或多个16位Unicode字符组成的字符序列(每个字符16位Unicode编码),即字符串。字符串既可以是双引号("")也可以是单引号('')表示。下面的表示都是合法的:
var str1 = “hello”;
var str2 = ‘hello’
这两种表示的语法在解释上没有任何区别,但必须匹配,否则会出现错误。
(1)有一些转义字符具有特殊含义:
\n (换行) \t(制表) \b(空格)
\r(回车) \f(进纸) \\(斜杠)
\’(单引号) \”(双引号)
(2)length:该属性返回字符串的长度。
关于汉子等双字节字符,length属性可能不会精确地返回字符串中的字符数目。(实际上,js中双字节字符算一个长度,是由unicode编码决定的(该编码用2个字节表示))
alert("软件系".length);//3