js 验证数据类型的4中方法

Posted 瘦子先生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 验证数据类型的4中方法相关的知识,希望对你有一定的参考价值。

1.typeof  可以检验基本数据类型 但是引用数据类型(复杂数据类型)无用;

总结 : typeof  无法识别引用数据类型  包括 bull; 

2.instanceof是一个二元运算符,左操作数是一个对象,右操作数是一个构造函数。如果左侧的对象是右侧构造函数的实例对象,则表达式返回true;否则返回false

  如果左操作数不是对象,返回false,如果右操作数不是函数,则抛出一个类型错误异常TypeError

  console.log(  true  instanceof Boolean)    // boolean
     console.log( "string" instanceof String)  // string
    console.log(   123 instanceof Number)    // number
    // console.log(  undefined instanceof   )  //语法错误
    console.log( function(){} instanceof  Function)  //function
    // console.log( null instanceof  null)     //语法错误
    console.log( [1,2,3] instanceof   Array)   //objet  
    console.log( {"name":"liming"} instanceof  Object )  // object

总结 :null  和 undefined  没有构造函数 使用此方法会报错!!! 无法鉴别基本数据类型  并且引用数据类型全部为对象 !!!

3.constructor

  实例对象的constructor属性指向其构造函数。如果是对象类型,则输出function 数据类型(){}; null  undefiend 报错

 

 4.Object.prototype.toString()方法

  对象的类属性是一个字符串,用以表示对象的类型信息。javascript没有提供设置这个属性的方法,但有一种间接方法可以查询它

  Object.prototype.toString()方法返回了如下格式的字符串:[object 数据类型]

console.log(Object.prototype.toString.call("string"));//[object String]
console.log(Object.prototype.toString.call(1));//[object Number]
console.log(Object.prototype.toString.call(true));//[object Boolean]
console.log(Object.prototype.toString.call(undefined));//[object Undefined]
console.log(Object.prototype.toString.call(null));//[object Null]

 

以上是关于js 验证数据类型的4中方法的主要内容,如果未能解决你的问题,请参考以下文章

js正则验证,邮箱,身份证

javascript [js:is()]从JavaScript Garden验证数据类型方法。 #js

教程4 - 验证和权限

js检查数据类型

代码安全之上传文件

求js代码。验证输入的数据是:4-16位字符,英文、数字、下划线的组合。