javascript中判断对象类型
<script type="text/javascript"> //判别一个对象属性在不在某个对象中
//in 是用于查找某个属性是否存在于对象中,它会把对象
//里面所有的内置方法全部返回 var json = {username:"pipi"};
console.log("username" in json); //true
console.log("toString" in json); //true
console.log("valueOf" in json); //true
console.log(json.constructor); //function Object();区分对象具体类型 console.log("=====================");
var date = new Date();
var arr = [];
var obj = {};
var regex = new RegExp(); console.log(date.constructor); //function Date()
console.log(arr.constructor); //function Array()
console.log(obj.constructor); //function Object()
console.log(regex.constructor); //function RegExp() /*
判断是否为数组
*/
function isArray(obj){
if(obj && typeof obj === "object"){
var con = obj.constructor.toString();
return con.indexOf("Array") != -1 ? true : false;
}
return false;
} function isArray1(obj){
return typeof obj.sort === "function";
} function isArray2(obj){
return obj != null && typeof obj === "object" && "splice" in obj && "join" in obj && "length" in obj;
} function isArray3(obj){
return obj instanceof Array;
} //ES5中提供的方法 IE678可能不支持
console.log(Array.isArray(arr)); //true
//自己定义
//prototype当做对象的方法动态扩展
Array.prototype.isArray = function(){
return this instanceof Array;
} console.log(isArray(arr)); //true
console.log(isArray1(arr)); //true
console.log(isArray2(arr)); //true
console.log(isArray3(arr)); //true //判断是否为数字
function isNumber(obj){
var num = new Number(obj);
return typeof obj === "number" && !("isNaN" in num);
} //判断是否为空
function isNull(obj){
return obj === null;
} //判断是否为undefined
function isUndefined(obj){
return obj === 0;
} //判断是不是一个日期类型
function isDate(obj){
if(obj && typeof obj === "object"){
var con = obj.constructor.toString();
return con.indexOf("Date") != -1 ? true :false;
}
return false;
} console.log(isDate(date));
/*
prototype是js为每一个对象提供的原型链
用于对象的动态扩展
*/
Array.prototype.isArray = function(){
return this instanceof Array;
} String.prototype.startWith = function(key){
return this.charAt(0) == key;
} String.prototype.endWith = function(key){
return this.charAt(this.length - 1) == key;
}
</script>
javascript中判断对象类型的更多相关文章
- JavaScript中判断对象类型方法大全1
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- JavaScript中判断对象类型的种种方法
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- 转 JavaScript中判断对象类型的种种方法
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- JavaScript中判断对象类型方法大全2
在JavaScript中,有5种基本数据类型和1种复杂数据类型,基本数据类型有:Undefined, Null, Boolean, Number和String:复杂数据类型是Object,Object ...
- JavaScript中判断对象是否属于Array类型的4种方法及其背后的原理与局限性
前言 毫无疑问,Array.isArray是现如今JavaScript中判断对象是否属于Array类型的首选,但是我认为了解本文其余的方法及其背后的原理与局限性也是很有必要的,因为在JavaScrip ...
- js中判断对象类型的几种方法
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- JavaScript中判断变量类型最简洁的实现方法以及自动类型转换(#################################)
这篇文章主要介绍了JavaScript中判断整字类型最简洁的实现方法,本文给出多个判断整数的方法,最后总结出一个最短.最简洁的实现方法,需要的朋友可以参考下 我们知道JavaScript提供了type ...
- Javascript 中判断对象为空
发现了一个巧妙的实现: 需要检查一个对象(Object)是否为空,即不包含任何元素.Javascript 中的对象就是一个字典,其中包含了一系列的键值对(Key Value Pair).检查一个对象是 ...
- JavaScript中的对象类型详解
To be finished 摘要 1.什么是对象? 2.引用类型和原始类型 3.对象数据属性拥有的特性(Attributes) 4.如何创建对象 a.直接定义 var mango={color:&q ...
随机推荐
- JDK NIO编程
我们首先需要澄清一个概念:NIO到底是什么的简称?有人称之为New I/O,因为它相对于之前的I/O类库是新增的,所以被称为New I/O,这是它的官方叫法.但是,由于之前老的I/O类库是阻塞I/O, ...
- 宫格布局实例(注意jquery的版本号要统一)2
<!DOCTYPE html><html><head><meta charset="utf-8" /><style> * ...
- 学好 Python 的 11 个优秀资源【转载】
Python是目前最流行.最易学最强大的编程语言之一(学习Python的五大理由),无论你是新手还是老鸟,无论是用于机器学习还是web开发(Pinterest就是案例),Python都是一件利器.此外 ...
- 分享Kali Linux 2016.2第42周镜像文件
分享Kali Linux 2016.2第42周镜像文件Kali Linux官方在10月16日发布Kali Linux 2016.2的第42周镜像文件.这一次不再像上几次,推迟提供32位镜像文件,而是同 ...
- 02_Java语言基础部分【总结】
1. 数据的输入/输出 标准输入输出流 字符输入: char c = (char)System.in.read(); 字符串输入: BufferedReader buf = new BufferedR ...
- node入门 express ejs
hello.js var express = require("express"); var app = express(); app.get("/hello" ...
- c++ 服务端 客户端
转载自:http://blog.csdn.net/orange_xxx/article/details/7276868 ,谢谢原作者. 作为个人学习的笔记使用. 服务端: // Server.cpp ...
- URAL1996 Cipher Message 3(KMP + FFT)
题目 Source http://acm.timus.ru/problem.aspx?space=1&num=1996 Description Emperor Palpatine has be ...
- Shell 编程基础之 Break, Continue 练习
一.语法 break:用来跳出循环.break N 可以跳出多层循环 break break N continue:用来跳过循环.continue N 可以跳过多层循环 continue contin ...
- Shell 编程基础之 While 练习
一.语法 while [ condition ] # 当 condition 条件成立时,就进行循环,直到条件不成立停止 do #执行内容 done 二.练习 输入用户输入的参数,直到用户输入 &qu ...