javascript数据类型验证方法


Posted in Javascript onDecember 31, 2015

最近对javascript数据类型的验证又有了一个新的认识,原来可以判断得这么简单又如此全面。
我们自定义了isString,isNumber ,isDate ,isError ,isRegExp ,isBoolean ,isNull ,isUndefined ,isObject等方法。现在将自己定义的javascript数据类型验证函数及测试集展示:

<!DOCTYPE html> 
<html> 
  <head> 
    <meta charset="utf-8"> 
    <title></title> 
  </head> 
  <body> 
     
  </body> 
<script type="text/javascript"> 
//isString 
//isNumber 
//isDate 
//isError 
//isRegExp 
//直接利用和数据类型来判断 
[].forEach.call(['String','Number','Date','Error','RegExp'],function(name){ 
  this['is'+name]=function(obj){ 
    return toString.call(obj)==='[object '+name+']'; 
  }; 
}); 
//isBoolean 
//true和false需要考虑在内 
Object.prototype.isBoolean=function(obj){ 
  return obj===true||obj===false||toString.call(obj)==='[object Boolean]'; 
}; 
//isNull 
//未找到所指向对象 
Object.prototype.isNull=function(obj){ 
  return obj===null; 
}; 
//isUndefined 
//定义了但是未赋值 
Object.prototype.isUndefined=function(obj){ 
  return obj===void 0; 
}; 
//isObject 
//函数和数组都是对象 
Object.prototype.isObject=function(obj){ 
  var type = typeof obj; 
  return type === 'function' || type === 'object' && !!obj; 
}; 
 
//test 
//isString 
var str="iamstring"; 
var a=isString(str); 
console.log(a);//true 
 
//isNumber 
var b=isNumber(a); 
console.log(b);//false 
 
//isNumber 
var num=4; 
var c=isNumber(num); 
console.log(c);//true 
 
//isRegExp 
var reg=/^[1-9]/; 
var d=isRegExp(reg); 
console.log(d);//true 
 
//isDate 
var date=new Date(); 
var e=isDate(date); 
console.log(e);//true 
 
//isBoolean 
var bool=false; 
var f=isBoolean(bool); 
console.log(f);//true 
 
//isNull 
var nul=document.getElementById("div02"); 
var g=isNull(nul); 
console.log(g);//true 
 
//isUndefined 
var undef; 
var h=isUndefined(undef); 
console.log(h);//true 
 
//isObject 
var obj={"1":"1","2":"2"}; 
var i=isObject(obj); 
console.log(i);//true 
 
</script> 
</html>

以下主要是对判断javascript的数据类型进行了详细的介绍,分为六种数据类型,需要的朋友可以过来参考下,希望对大家有所帮助
1、判断是否为数组类型
代码如下:

<STRONG><script type="text/javascript"> 
//<![CDATA[ 
var a=[0]; 
document.write(isArray(a),'<br/>'); 
function isArray(obj){ 
return (typeof obj=='object')&&obj.constructor==Array; 
} 
//]]> 
</script></STRONG>

2 判断是否为字符串类型
代码如下:

<script type="text/javascript"> 
//<![CDATA[ 
document.write(isString('test'),'<br/>'); 
document.write(isString(10),'<br/>'); 
function isString(str){ 
return (typeof str=='string')&&str.constructor==String; 
} 
//]]> 
</script>

3 判断是否为数值类型
代码如下:

<script type="text/javascript"> 
//<![CDATA[ 
document.write(isNumber('test'),'<br/>'); 
document.write(isNumber(10),'<br/>'); 
function isNumber(obj){ 
return (typeof obj=='number')&&obj.constructor==Number; 
} 
//]]> 
</script>

4 判断是否为日期类型
代码如下:

<script type="text/javascript"> 
//<![CDATA[ 
document.write(isDate(new Date()),'<br/>'); 
document.write(isDate(10),'<br/>'); 
function isDate(obj){ 
return (typeof obj=='object')&&obj.constructor==Date; 
} 
//]]> 
</script>

5 判断是否为函数
代码如下:

<script type="text/javascript"> 
//<![CDATA[ 
document.write(isFunction(function test(){}),'<br/>'); 
document.write(isFunction(10),'<br/>'); 
function isFunction(obj){ 
return (typeof obj=='function')&&obj.constructor==Function; 
} 
//]]> 
</script>

6 判断是否为对象
代码如下:

<script type="text/javascript">
linenum
//<![CDATA[ 
document.write(isObject(new Object()),'<br/>'); 
document.write(isObject(10),'<br/>'); 
function isObject(obj){ 
return (typeof obj=='object')&&obj.constructor==Object; 
} 
//]]> 
</script>

希望本文所述对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
表单的一些基本用法与技巧
Jul 15 Javascript
js身份证验证超强脚本
Oct 26 Javascript
基于jquery扩展漂亮的下拉框可以二次修改
Nov 19 Javascript
JQuery弹出层示例可自定义
May 19 Javascript
javascript实现英文首字母大写
Apr 23 Javascript
浅析JavaScript动画模拟拖拽原理
Dec 09 Javascript
Vue form 表单提交+ajax异步请求+分页效果
Apr 22 Javascript
解决option标签selected=&quot;selected&quot;属性失效的问题
Nov 06 Javascript
微信网页授权并获取用户信息的方法
Jul 30 Javascript
vue Treeselect 树形下拉框:获取选中节点的ids和lables操作
Aug 15 Javascript
详解如何使用Node.js实现热重载页面
May 06 Javascript
详解JavaScript的计时器和按钮效果设置
Feb 18 Javascript
jQuery操作基本控件方法实例分析
Dec 31 #Javascript
javascript图片延迟加载实现方法及思路
Dec 31 #Javascript
jQuery动画显示和隐藏效果实例演示(附demo源码下载)
Dec 31 #Javascript
详解javascript高级定时器
Dec 31 #Javascript
jQuery动画效果相关方法实例分析
Dec 31 #Javascript
js实现文字垂直滚动和鼠标悬停效果
Dec 31 #Javascript
jquery正则表达式验证(手机号、身份证号、中文名称)
Dec 31 #Javascript
You might like
PHP操作mysql函数详解,mysql和php交互函数
2011/05/19 PHP
php防注入及开发安全详细解析
2013/08/09 PHP
PHP中读取文件的几个方法总结(推荐)
2016/06/03 PHP
Ajax实现对静态页面的文章访问统计功能示例
2016/10/10 PHP
showModelessDialog()使用详解
2006/09/21 Javascript
js局部刷新页面时间具体实现
2013/07/04 Javascript
JS短路原理的应用示例 精简代码的途径
2013/12/13 Javascript
基于jquery实现导航菜单高亮显示(两种方法)
2015/08/23 Javascript
IE中document.createElement的iframe无法设置属性name的解决方法
2015/09/14 Javascript
js实现图片上传并正常显示
2015/12/19 Javascript
js实现的万能flv网页播放器代码
2016/04/30 Javascript
全面解析JavaScript中的valueOf与toString方法(推荐)
2016/06/14 Javascript
JavaScript 数组- Array的方法总结(推荐)
2016/07/21 Javascript
JavaScript构建自己的对象示例
2016/11/29 Javascript
jQuery实现最简单实用的分秒倒计时
2017/02/05 Javascript
老生常谈jquery中detach()和remove()的区别
2017/03/02 Javascript
vue 组件中slot插口的具体用法
2018/04/03 Javascript
JavaScript原型式继承实现方法
2019/11/06 Javascript
VueJS实现用户管理系统
2020/05/29 Javascript
python插入排序算法实例分析
2015/07/03 Python
Python+OpenCV让电脑帮你玩微信跳一跳
2018/01/04 Python
django 按时间范围查询数据库实例代码
2018/02/11 Python
python使用生成器实现可迭代对象
2018/03/20 Python
Python sklearn KFold 生成交叉验证数据集的方法
2018/12/11 Python
Python开发网站目录扫描器的实现
2019/02/21 Python
python算法题 链表反转详解
2019/07/02 Python
python multiprocessing模块用法及原理介绍
2019/08/20 Python
Python3 利用face_recognition实现人脸识别的方法
2020/03/13 Python
Python 创建TCP服务器的方法
2020/07/28 Python
python基于opencv实现人脸识别
2021/01/04 Python
世界上最大的糖果店:Dylan’s Candy Bar
2017/11/07 全球购物
音乐专业应届生教师求职信
2013/11/04 职场文书
敬老院院长事迹材料
2014/05/21 职场文书
2014年英语教研组工作总结
2014/12/06 职场文书
初中语文教师研修日志
2015/11/13 职场文书
pytorch 实现多个Dataloader同时训练
2021/05/29 Python