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的规范中给出了一个方法来获得现 ...
随机推荐
- HDU 2579 (记忆化BFS搜索)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2579 题目大意:走迷宫.对于障碍点,只有当前(dep+1)%k才能走,问最少时间. 解题思路: 只有 ...
- java中的sleep()和wait()的区别
对于sleep()方法,我们首先要知道该方法是属于Thread类中的.而wait()方法,则是属于Object类中的. sleep()方法导致了程序暂停执行指定的时间,让出cpu该其他线程,但是他的监 ...
- JAVA中使用FTPClient实现文件上传下载
在JAVA程序中,经常需要和FTP打交道,比如向FTP服务器上传文件.下载文件,本文简单介绍如何利用jakarta commons中的FTPClient(在commons-net包中)实现上传下载文件 ...
- FLTK 1.1.10 VS2010 Configuration 配置
Download FLTK 1.1.10 at here. Download VS2010 Download CMake 2.8.12 I assume you've already installe ...
- include动作标记和include指令标记学习笔记
我的jsp学习参考书是耿祥义,张跃平编著的jsp大学使用教程这本书,我也向大家推荐这本书,我觉得这本书适合我的学习方式,知识的讲解透彻易懂. include指令标记 ...
- 红,X-Japan
ktv如果唱这首应该很爽,慢慢学. 红(くれない) 歌手:X JAPAN作词:YOSHIKI作曲:YOSHIKI I could not look back you'd gone away from ...
- 【iM_VGA模块】运行 ucgui 演示!
挂在 iCore2 双核心板上的 VGA模块,跑 ucgui DEMO 演示.大家看看! ============================== 技术论坛:http://www.eeschool ...
- 清橙 A1206 小Z的袜子(莫队算法)
A1206. 小Z的袜子 时间限制:1.0s 内存限制:512.0MB 总提交次数:1357 AC次数:406 平均分:46.75 将本题分享到: 查看未格式化的试题 ...
- 前端编码规范(4)—— CSS 和 Sass (SCSS) 规范
CSS and Sass (SCSS) style rules ID and class naming ID和class(类)名总是使用可以反应元素目的和用途的名称,或其他通用名称.代替表象和晦涩难懂 ...
- DateTime Related Functions
string a = "to_date('" + dtpStart.Value.ToString("yyyy/MM/dd") + "', 'yyyy/ ...