JS中的数据类型检测

JavaScript的数据类型分为两类:原始类型(primitive type)和对象类型(object type)。原始类型有5种,分别是:数字(Number)、字符串(String)、布尔值(Boolean)、null和undefined。引用类 型包括:Object、Array、Date、Error、RegExp、Functions。

1.原始类型的检测

对于原始类型中的:数字、字符串、布尔值、undefined,最佳检测方法是使用typeof运算符,typeof检测后会返回一个表示值类型的字符串。typeof的语法是:

typeof <变量>
typeof(<变量>)

对以上4种原始值使用typeof运算符后:数字返回"number" 、    字符串返回"string" 、    布尔值返回"boolean" 、    undefined返回"undefined"。如下:

var str = 'a string';
console.log(typeof str);           //      ->   string

var num = 0;
console.log(typeof num);           //      ->   string

var bool = true;
console.log(typeof bool);          //      ->   boolean

var undefin;
console.log(typeof undefin);               //      ->   undefined  未定义的变量和未初始化的变量都将返回undefined

原始值null,应当使用===和!==进行行比较,对null做typeof检测时,返回值为"object"。

2.引用类型的检测

引用值也称做对象(object),在JavaScript中除原始类型外都是引用类型。typeof运算符不能有效检测引用类型,所有引用类型都会返回“object”:

console.log(typeof []);              //      ->   object
console.log(typeof new Date());           //      ->   object
console.log(typeof {});                //      ->   object
console.log(typeof new Error());    //    ->   object
console.log(typeof new RegExp());    //   ->   object
console.log(typeof Function);    //    ->   function

引用类型检测推荐使用instanceof运算符,基本语法是:

value instanceof constructor

对引用类型做instanceof操作:

console.log([] instanceof Array);                //      ->   true
console.log(new Date() instanceof Date);        //       ->   true
console.log({} instanceof Object);            //      ->   true
console.log(new Error() instanceof Error);       //      ->   true
var reg = new RegExp();
console.log(reg instanceof RegExp);             //   ->   true
function func (argument) {
}
console.log(func instanceof Function)           //     ->   true

对于函数做typeof操作返回function,相比intanceof更推荐使用typeof。

对象属性检测

判断属性是否存在最好的方法是使用in运算符,如果属性存在或继承自原型链,都会返回true。如果只想检测对象实例是否存在某属性,而不是从原型继承的属性则使用hasOwnProperty()方法。如下:

function Person() {
    this.name = 'liuht';
    this.doSometing = function() {
        return 'doSometing';
    }
}
Person.prototype.area = 'China';              // 原型链属性

var man = new Person();
man.sex = 'man';

console.log('name' in man);           //         -> true
console.log('sex' in man);            //      -> true
console.log('area' in man);           //      -> true

console.log(man.hasOwnProperty('name'));                //      -> true
console.log(man.hasOwnProperty('sex'));                 //      -> true
console.log(man.hasOwnProperty('area'));                        //      -> false
posted @ 2016-10-12 19:21  salody  阅读(141)  评论(0编辑  收藏  举报