javascript验证数据类型
2015-07-02 09:27
471 查看
最近通过对Underscore.js源码的学习,对javascript数据类型的验证又有了一个新的认识,原来可以判断得这么简单又如此全面。
我们自定义了isString,isNumber ,isDate ,isError ,isRegExp ,isBoolean ,isNull ,isUndefined ,isObject等方法。现在将自己定义的javascript数据类型验证函数及测试集展示:
代码的位置在:
http://runjs.cn/code/ucwpitro
我们自定义了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>
代码的位置在:
http://runjs.cn/code/ucwpitro
相关文章推荐
- 处理json中的null
- 把表单数据封装成json格式 插件可用
- HTML5的自定义属性data-*详细介绍和JS操作实例
- json转换之Gson
- JavaScriptSerializer
- [CodeWars][JS]实现链式加法
- JS中windows对象方法
- ajaxfileupload.js 实现异步上传图片
- JSP基础实例_登录页面的制作_学习笔记
- JavaScript实现广告的关闭与显示效果实例
- JavaScript获取并更改input标签name属性的方法
- javascript获取select值的方法分析
- JavaScript实现动态添加,删除行的方法实例详解
- JS验证IP,子网掩码,网关和MAC的方法
- JavaScript实现单击下拉框选择直接跳转页面的方法
- JavaScript实现添加、查找、删除元素
- javascript实现简单的进度条
- JS实现从连接中获取youtube的key实例
- js跨域请求的5中解决方式
- JavaScript获得url查询参数的方法