数据类型
数值 文本 图形 音频 视频……
number :
js 不区分小数和整数 Number
123 // 整数
123.11 //浮点数
123.e2 //科学计数法
-998 //负数
NaN // not a number
Infinity // 表示这个熟悉无穷大
逻辑运符
&& 两个都为真,结果为真
|| 其中一个为真,结果为真
! 真即是假, 假即是真
比较运算符 !!!!重要
=
== 等于(类型不一样 值一样 也会判断为true)
=== 绝对等于(类型一样 值一样 才会判断为 true)
这个是JS的缺陷 在比较的时候尽量使用 === 进行比较
须知:
- NaN ===NaN 这个与所有的数值都不不相等 ,包括自身。
- 只能通过 isNaN(NaN) 来判断这个数是否为 NaN
一、JS中的数据类型
1.数值型(Number):包括整数、浮点数。
浮点数问题:
console.log((1/3)====(1-2/3)) //false
尽量避免使用浮点数 进行运算,存在精度问题!
Math.abs(1/3-(1-2/3))>0.000000000001 //返回 true 这样我们姑且认为他是 一样的
2.布尔型(Boolean)
ture false
3.字符串型(String)
'dfs' "dfsd"
4.对象(Object)
对象是大括号,数组是中括号
每个属性之间使用逗号隔开,最后一个属性不需要添加
5.数组(Array)
Java的数组必须是相同类型的对象, JS不需要这样
//为了保证代码的可读性 尽量使用[]
var a=[1,2,3,'1231',true,null];
new Array(1,2,3,4,true,null)
取数组下标:如果数组下表越界了 返回:undefined
6.空值(Null)
7.未定义(Undefined)
二、判断一个变量的数据类型
1、数值型(number)
比较常用的判断方法是:
function isNumber(val){
return typeof val === 'number';
}
var a;
isNumber(parseInt(a));
但有些情况就不行,比如上面判断a,就是true,这显然是不对的:
实际上变量a是NaN,它是不能用于数值运算的。所以上面的函数可以修改为:
function isNumber(val){
return typeof val === 'number' && isFinite(val);
}
修改之后就正确了,顺便介绍一下JavaScript isFinite() 函数,isFinite() 函数用于检查其参数是否是无穷大,如果 number 是有限数字(或可转换为有限数字),那么返回 true。否则,如果 number 是 NaN(非数字),或者是正、负无穷大的数,则返回 false。
2、布尔型(boolean)
布尔类型的判断比较简单,可以用如下的方法进行判断:
//判断变量val是不是布尔类型
function isBooleanType(val) {
return typeof val ==="boolean";
}
3、字符串(String)
字符串类型的判断比较简单,可以用如下的方法进行判断:
//判断变量val是不是字符串类型
function isStringType(val) {
return typeof val ==="string";
}
4、未定义(Undefined)
未定义的判断比较简单,可以用如下的方法进行判断:
//判断变量val是不是undefined
function isUndefined(val) {
return typeof val ==="undefined";
}
5、对象(Object)
由于当变量是空值Null时,typeof也会返回object,所以Object不能直接用 typeof 判断。应该这样:
//判断变量是不是Object类型
function isObj(str){
if(str === null || typeof str === 'undefined'){
return false;
}
return typeof str === 'object';
}
6、空值(Null)
判断空值用 val === null 即可
//判断变量是不是Null
function isNull(val){
return val === null;
}
7、数组(Array)
数组类型不可用typeof来判断。因为当变量是数组类型时,typeof会返回object。
这里有两种方法判断数组类型:
/*判断变量arr是不是数组
方法一
*/
function isArray1(arr) {
return Object.prototype.toString.apply(arr) === '[object Array]';
}
/*判断变量arr是不是数组
方法二
*/
function isArray2(arr) {
if(arr === null || typeof arr === 'undefined'){
return false;
}
return arr.constructor === Array;
}