今天看js高程,注意到很多以前没有注意到的知识,和一些以前看过却忘了的地方。记录一下方便以后复习和翻阅。
1. 调用typeof null 会返回object ,因为特殊值null被认为是一个空的对象引用。Safari 5 及之前版本、Chrome 7 及之前版本在对正则表达式调用 typeof 操作符时会返回"function",而其他浏览器在这种情况下会返回"object"。
另:typeof是一个操作符,而不是一个函数,所以调用时虽然可以使用括号,但是不用括号也并不影响。
2. 未定义的变量alert出来的值会报错,然而typeof未定义的变量,会报 undefined
例:
var message; // 这个变量声明之后默认取得了 undefined 值
// 下面这个变量并没有声明
// var age
alert(message); // "undefined"
alert(age); // 产生错误
var message; // 这个变量声明之后默认取得了 undefined 值
// 下面这个变量并没有声明
// var age
alert(typeof message); // "undefined"
alert(typeof age); // "undefined"
3.undefined和null都只有一个值。
4.整数可以通过八进制(以 8 为基数)或十六进制(以 16 为基数)的字面值来表示。其中,八进制字面值的第一位必须是零(0),然后是八进制数字序列(0~7)。如果字面值中的数值超出了范围,那么前导零将被忽略,后面的数值将被当作十进制数值解析。例:
var octalNum1 = 070; // 八进制的 56
var octalNum2 = 079; // 无效的八进制数值——解析为 79
var octalNum3 = 08; // 无效的八进制数值——解析为 8
八进制字面量在严格模式下是无效的,会导致支持的 JavaScript 引擎抛出错误。
十六进制字面值的前两位必须是0x,如 var cd=0xA;
在进行算术运算时,八进制和十六进制最终都被转换成十进制。
5. 保存浮点数需要的内存空间是保存整数的两倍。
对于极大或极小的数值可以用科学表示法(即e表示法,2e10=2x10的10次方。3e-7=3x10的7次方);
浮点数的计算精度较小。例:0.1 加 0.2的结果不是 0.3,而是 0.30000000000000004。
6. -Infinity(负无穷),Infinity(正无穷)。想判断数值是不是有穷,可以使用isFinite()函数,在正无穷和负无穷之间,该函数会返回true。
7.NaN是用于返回一个本来要返回数值而未返回数值的情况。NaN和任何值都不相等, 包括NaN本身。0 除以 0 会返回 NaN,正数除以 0 返回 Infinity,负数除以 0 返回-Infinity。
8.null转换数字为0,undefined为NaN。
Number()里字符串转换数字时,数字里“023”会转换成23,先导0会被忽略。十六进制等会被转换成相同大小的十进制。空字符串为0,。其他格式字符串返回NaN。
parseInt()解析第一个字符不是数字字符或者负号时就会返回NaN。接着它会解析下来的字符,直到遇到第一个非数字字符停止。例:parseInt(“1234il”)会返回1234。parseInt(“23.5”)会返回23,因为小数点并不是有效的数字字符。
parseInt()第二个参数是传入指定用什么进制解析数字。
例:var six=parseInt(“AB”,16);//按十六进制解析
parseFloat()从第一个字符解析到末尾。始终忽略前导0,只解析十进制数。解析到末尾遇到第一个失效的小数点字符为止。
例 :parseFloat(“22.55.6”) //22.55