JS判断对象类型
对于确定JS内置对象类型,JS提供了typeof运算符,该运算符得到的结果为以下6种:number,boolean,string,function,object,undefined.不过对绝大多数对象而言,typeof都返回"object",无法确定具体的类型。我们使用一种函数Object.prototype.toString.call来判断
<script> var a = 1; console.log("a:"+typeof a); //number console.log("a:"+Object.prototype.toString.call(a)); //[object Number] var b = NaN; console.log("b:"+typeof b); //number console.log("b:"+Object.prototype.toString.call(b)); //[object Number] var c= Number.MIN_VALUE; console.log("c:"+typeof c); //number console.log("c:"+Object.prototype.toString.call(c)); //[object Number] var d= Infinity; console.log("d:"+typeof d); //number console.log("d:"+Object.prototype.toString.call(d)); //[object Number] var e= "pmx"; console.log("e:"+typeof e); //string console.log("e:"+Object.prototype.toString.call(e)); //[object String] var f= true; console.log("f:"+typeof f); //boolean console.log("f:"+Object.prototype.toString.call(f)); //[object Boolean] var g= window; console.log("g:"+typeof g); //object console.log("g:"+Object.prototype.toString.call(g)); //[object Window] var h = [1]; console.log("h:"+typeof h); //object console.log("h:"+Object.prototype.toString.call(h)); //[object Array] var i = function(){}; console.log("i:" + typeof i); //function console.log("i:"+Object.prototype.toString.call(i)); //[object Function] var j = document; console.log("j:" + typeof j); //object console.log("j:"+Object.prototype.toString.call(j)); //[object HTMLDocument] var k = null; console.log("k:" + typeof k); //object console.log("k:"+Object.prototype.toString.call(k)); //[object Null] var l = undefined; console.log("l:" + typeof l); //undefined console.log("l:"+Object.prototype.toString.call(l)); //[object Undefined] var m = eval; console.log("m:" + typeof m); //function console.log("m:"+Object.prototype.toString.call(m)); //[object Function] var n = new Date(); console.log("n:" + typeof n); //object console.log("n:"+Object.prototype.toString.call(n)); //[object Date] </script>
将Object.prototype.toString.call的返回值处理下,使得更直观
var Adsame =function(){ }; Adsame.prototype.whichType = function(){ var class2type = {}; var types = "Boolean Number String Function Array Date RegExp Object Error Undefined Null"; types = types.split(" "); for(var i = 0; i<types.length; i++){ class2type["[object "+types[i]+"]"] = types[i].toLowerCase(); } var params = arguments; var params_len = params.length; var param_arr = Array.prototype.slice.call(params); var result = [] ; for(var k = 0; k<params_len; k++){ var type = Object.prototype.toString.call(param_arr[k]); result.push(class2type[type]); } return result.length ? result: "undefined" ; }
JS中还有个类似的运算符instanceof,它是用来判断某个对象是否是某类型的实例
<script> var a = function(){} console.log(a instanceof Object);//true var b = 1; console.log(b instanceof Object);//false var c = "1"; console.log(c instanceof Object);//false var d = true; console.log(d instanceof Object);//false var e = undefined; console.log(e instanceof Object);//false var f = null; console.log(f instanceof Object);//false var g = [1]; console.log(g instanceof Object);//true var h = window; console.log(h instanceof Object);//gte IE 9:true,lt IE 9:false </script>
可以看到,JS中的5中基本类型number,string,boolean,undefined,null并不是Object的实例。
对于低版本的浏览器认为window对象是dom里面的属性,和JS对象是两码事
JS判断对象类型的更多相关文章
- js 判断对象类型
在企业级的开发中,我们常用 typeof 来判断企业 对象类型:但是 typeof 不能判断 Array 和 null 这里我们使用一个 原型上的 toString方法:请看一下代码: <scr ...
- html5 -js判断undefined类型
js判断undefined类型 今天使用showModalDialog打开页面,返回值时.当打开的页面点击关闭按钮或直接点浏览器上的关闭则返回值是undefined所以自作聪明判断 var reVal ...
- js判断浏览器类型 js判断ie6不执行
js判断浏览器类型 $.browser 对象 $.browser.version 浏览器版本 var binfo = ''; if ($.browser.msie) { binfo = " ...
- js判断undefined类型,undefined,null,NaN的区别
js判断undefined类型 今天使用showModalDialog打开页面,返回值时.当打开的页面点击关闭按钮或直接点浏览器上的关闭则返回值是undefined 所以自作聪明判断 ...
- js验证对象类型
js验证对象类型 1. Object.prototype.toString.call() 这是最佳解决方案,可以用作通用方式处理.各种类型的判断依据类似于[object Object],替换的是后边的 ...
- js判断undefined类型,undefined,null, 的区别详细解析
js判断undefined类型 今天使用showModalDialog打开页面,返回值时.当打开的页面点击关闭按钮或直接点浏览器上的关闭则返回值是undefined所以自作聪明判断 var reVal ...
- js判断undefined类型
js判断undefined类型 if (reValue== undefined){ alert("undefined"); } 发现判断不出来,最后查了下资料要用ty ...
- Js判断对象是否为空,Js判断字符串是否为空
Js判断对象是否为空,Js判断字符串是否为空,JS检查字符串是否为空字符串 >>>>>>>>>>>>>>>&g ...
- 通过JS判断联网类型和连接状态
通过JS判断联网类型和连接状态 中国的移动网络环境复杂,为了给用户带去更好访问体验,开发者希望能了解用户当前的联网方式,然后给用户一个符合当前网络环境的请求结果. W3C的规范中给出了一个方法来获得现 ...
随机推荐
- [Unity2D]脚本基类MonoBehaviour介绍
Unity中的脚本都是继承自MonoBehaviour. MonoBehaviour 表示一个单一的行为.Unity中用户对游戏对象的操作被分割成若干个单一行为.每个单一行为都作为一个MonoBeha ...
- USACO 5.4 Telecowmunication(最大流+枚举)
面对最小割之类的题目,完全木想法... 枚举+最大流..复杂度很大了...居然很快的就过了.. /* ID: cuizhe LANG: C++ TASK: telecow */ #include &l ...
- COJ885 LCS???
试题描述 输入两个字符串A.B,输出他们的最长连续公共子串长度. 输入 第一行为一个字符串A. 第二行为一个字符串B. 输出 输出他们的最长连续公共子串长度. 输入示例 ababab bababbab ...
- Spring动态配置多数据源
Spring动态配置多数据源,即在大型应用中对数据进行切分,并且采用多个数据库实例进行管理,这样可以有效提高系统的水平伸缩性.而这样的方案就会不同于常见的单一数据实例的方案,这就要程序在运行时根据当时 ...
- HTML练习----注册界面
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- maven--私服的搭建(Nexus的使用)
Nexus常用功能就是:指定私服的中央地址.将自己的Maven项目指定到私服地址.从私服下载中央库的项目索引.从私服仓库下载依赖组件.将第三方项目jar上传到私服供其他项目组使用. 开启Nexus服务 ...
- spring redis整合
1,利用spring-data-redis整合 项目使用的pom.xml: <project xmlns="http://maven.apache.org/POM/4.0.0" ...
- GC-垃圾回收
代:0代,1代,2代: 所谓第几代,指经历过GC回收的次数. 回收算法: 1.确认需要检查的代. 在分配新对象时, 如果第0代已满,则进行检查:如果第1代已满,则进行检查:第2代同理: 如第0代没有足 ...
- maven-surefire-plugin总结
Maven通过Maven Surefire Plugin插件执行单元测试.(通过Maven Failsafe Plugin插件执行集成测试) 在pom.xml中配置JUnit,TestNG测试框架的依 ...
- 实现ScrollView中包含ListView,动态设置ListView的高度
ScrollView 中包含 ListView 的问题 : ScrollView和ListView会冲突,会导致ListView显示不全 <?xml version="1.0" ...