用来判别类型的方法有好多,整理了一下4种方法,平时用的时候,在不同情景下,还是要结合着使用的。

方法一

typeof:可以识别标准类型,除了Null;不能识别具体的对象类型,除了Function

<script>
var t = typeof(1);
console.log(t); // t==="number" var t = typeof(new Number(1))
console.log(t); // t==="object" var t = typeof("abc");
console.log(t); // t==="string" var t = typeof(new String("abc"));
console.log(t); // t==="object" var t = typeof(true);
console.log(t); // t==="boolean" var t = typeof(undefined);
console.log(t); // t==="undefined" var t = typeof(null);
console.log(t); // t==="object" var t = typeof({});
console.log(t); // t==="object" var t = typeof([]);
console.log(t); // t==="object" var t = typeof(new Date);
console.log(t); // t==="object" var t = typeof(/\d/);
console.log(t); // t==="object" var t = typeof(function(){});
console.log(t); // t==="function"
</script>

方法二

instanceof:可以识别内置对象类型,不能识别原始类型,可以识别自定义对象类型

<script>
var t = new Number(1);
console.log(1 instanceof Number); // false
console.log(1 instanceof Object); // false
console.log(t instanceof Number); // true
console.log(t instanceof Object); // true var t = new String("abc");
console.log("abc" instanceof String); // false
console.log("abc" instanceof Object); // false
console.log(t instanceof String); // true
console.log(t instanceof Object); // true console.log(true instanceof Boolean); // false
console.log(true instanceof Object); // false console.log(undefined instanceof Object); // false
console.log(undefined instanceof Undefined); // Uncaught ReferenceError: Undefined is not defined console.log(null instanceof Object); // false
console.log(null instanceof Null); // Uncaught ReferenceError: Undefined is not defined var t = new Object({});
console.log(t instanceof Object); // true
console.log({} instanceof Object); // true var t = new Array([]);
console.log(t instanceof Array); // true
console.log(t instanceof Object); // true
console.log([] instanceof Array); // true
console.log([] instanceof Object); // true var t = new Date();
console.log(t instanceof Date); // true
console.log(t instanceof Object); // true console.log(/\d/ instanceof Object); // true
console.log(/\d/ instanceof Regexp); // Uncaught ReferenceError: Undefined is not defined var t = function(){};
console.log(t instanceof Function); // true
console.log(t instanceof Object); // true
</script>

方法三:可以识别标准类型以及内置对象类型,不能识别自定义类型

    function type(obj){
return Object.prototype.toString.call(obj).slice(8,-1);
}

示例:

<script>
var t = type(1);
console.log(t); // t==="Number" var t = type(new Number(1));
console.log(t); // t==="Number" var t = type("abc");
console.log(t); // t==="String" var t = type(new String("abc"));
console.log(t); // t==="String" var t = type(true);
console.log(t); // t==="Boolean" var t = type(undefined);
console.log(t); // t==="Undefined" var t = type(null);
console.log(t); // t==="Null" var t = type({});
console.log(t); // t==="Object" var t = type([]);
console.log(t); // t==="Array" var t = type(new Date);
console.log(t); // t==="Date" var t = type(/\d/);
console.log(t); // t==="Regexp" var t = type(function(){});
console.log(t); // t==="Function" function add(){};
var f = new add();
var t = type(f);
console.log(t); // t==="Object"
</script>

方法四:可以识别所有类型:标准类型、内置对象类型、自定义对象类型

        function getConstructorName(obj){
return (obj===undefined||obj===null)?obj:(obj.constructor&&obj.constructor.toString().match(/function\s*([^(]*)/)[1]);
}

示例:

<script>
var t = getConstructorName(1);
console.log(t); // t==="Number" var t = getConstructorName(new Number(1));
console.log(t); // t==="Number" var t = getConstructorName("abc");
console.log(t); // t==="String" var t = getConstructorName(new String("abc"));
console.log(t); // t==="String" var t = getConstructorName(true);
console.log(t); // t==="Boolean" var t = getConstructorName(undefined);
console.log(t); // t==="undefined" var t = getConstructorName(null);
console.log(t); // t==="null" var t = getConstructorName({});
console.log(t); // t==="Object" var t = getConstructorName([]);
console.log(t); // t==="Array" var t = getConstructorName(new Date);
console.log(t); // t==="Date" var t = getConstructorName(/\d/);
console.log(t); // t==="Regexp" var t = getConstructorName(function(){});
console.log(t); // t==="Function" function add(){};
var f = new add();
var t = getConstructorName(f);
console.log(t); // t==="add"
</script>

Demo:

输入任意格式的年月日,均返回 Date 格式:

/*
* 输入格式:
* '2016-11-06'
* 1478401733333
* {y:2016,m:11,d:6}
* [2016,11,6]
* 返回格式:Date
*/
function toDate(param){
if (typeof(param) == 'string' ||
typeof(param) == 'number' ){
return new Date(param);
}
if (param instanceof Array){
var date = new Date(0);
date.setYear(param[0]);
date.setMonth(param[1]-1);
date.setDate(param[2]);
return date;
}
if (typeof(param) == 'object') {
var date = new Date(0);
date.setYear(param.y);
date.setMonth(param.m-1);
date.setDate(param.d);
return date;
}
return -1;
}

js学习之类型识别的更多相关文章

  1. JS中的类型识别

    JS为弱类型语言,所以类型识别对JS而言尤为重要,JS中常用的类型识别方法有4种:typeof.Object.prototype.toString.constructor和instanceof. (1 ...

  2. 关于js中的类型内容总结(类型识别)

    JS 有7种数据类型: 6种原始类型:Boollean    String   Number    Null    Underfined   Symbol 引用类型:Object 类型识别主要有以下四 ...

  3. JS学习笔记(一)基本数据类型和对象类型

    js是一种弱类型的语言,所有的变量都用var进行声明,字符串用双引号或单引号括起来,常见基本数据类型为number,string,boolean等.如 var num = 123;或var num = ...

  4. WebGL three.js学习笔记 6种类型的纹理介绍及应用

    WebGL three.js学习笔记 6种类型的纹理介绍及应用 本文所使用到的demo演示: 高光贴图Demo演示 反光效果Demo演示(因为是加载的模型,所以速度会慢) (一)普通纹理 计算机图形学 ...

  5. JS 学习笔记--8---Function类型

    练习使用的浏览器IE11   JS 中Function类型实际上是一种对象,每一个函数实际上都是Function类型的一个实例,每一个函数都有一些默认的属性和方法.由于函数是对象,故函数名实际上也是一 ...

  6. (C/C++学习笔记) 二十三. 运行时类型识别

    二十三. 运行时类型识别 ● 定义 运行时类型识别(Run-time Type Identification, RTTI) 通过RTTI, 程序能够使用基类的指针或引用来检查(check)这些指针或引 ...

  7. C++学习之显式类型转换与运行时类型识别RTTI

    static_cast const_cast reinterpret_cast 运行时类型识别(RTTI) dynamic_cast 哪种情况下dynamic_cast和static_cast使用的情 ...

  8. Javascript 基础学习(三)js 的原始类型和声明变量

    java的基本数据类型一共有 byte short int long float double char boolean js中定义变量使用关键字 var js的原始类型(五个) String: 字符 ...

  9. Ext JS学习第十六天 事件机制event(一) DotNet进阶系列(持续更新) 第一节:.Net版基于WebSocket的聊天室样例 第十五节:深入理解async和await的作用及各种适用场景和用法 第十五节:深入理解async和await的作用及各种适用场景和用法 前端自动化准备和详细配置(NVM、NPM/CNPM、NodeJs、NRM、WebPack、Gulp/Grunt、G

    code&monkey   Ext JS学习第十六天 事件机制event(一) 此文用来记录学习笔记: 休息了好几天,从今天开始继续保持更新,鞭策自己学习 今天我们来说一说什么是事件,对于事件 ...

随机推荐

  1. 如何一步一步用DDD设计一个电商网站(三)—— 初涉核心域

    一.前言 结合我们本次系列的第一篇博文中提到的上下文映射图(传送门:如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念),得知我们这个电商网站的核心域就是销售子域.因为电子商务是以信息网络 ...

  2. 10个最好用的HTML/CSS 工具、插件和资料库

    大家在使用HTML/CSS开发项目的过程中,有使用过哪些工具,插件和库?下面介绍的10种HTML/CSS工具,插件和资料库,是国外程序员经常用到的. Firebug Lite FirebugLite ...

  3. 【原】AFNetworking源码阅读(三)

    [原]AFNetworking源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇的话,主要是讲了如何通过构建一个request来生成一个data tas ...

  4. Spring框架概述

    Spring是最流行的Java企业级应用开发框架,全球数以百万的开发者在使用Spring框架创建高性能.易测试.可重用的代码. Spring框架的核心特性可以应用于任何Java应用,但扩展的JavaE ...

  5. python开发环境搭建

    虽然网上有很多python开发环境搭建的文章,不过重复造轮子还是要的,记录一下过程,方便自己以后配置,也方便正在学习中的同事配置他们的环境. 1.准备好安装包 1)上python官网下载python运 ...

  6. ASP.NET MVC开发:Web项目开发必备知识点

    最近加班加点完成一个Web项目,使用Asp.net MVC开发.很久以前接触的Asp.net开发还是Aspx形式,什么Razor引擎,什么MVC还是这次开发才明白,可以算是新手. 对新手而言,那进行A ...

  7. 几个有趣的WEB设备API 前端提高B格必备(一)——电池状态&震动api

    受到同事启发,突然发现了几个有趣又实用的web api,没想到前端还有这么多有趣的东西可以玩~~简直过分. 1.电池状态API navigator.getBattery():这个api返回的是一个pr ...

  8. 【一起学OpenFoam】02 软件准备

    "工欲善其事必先利其器",在利用OpenFoam解决我们的工程问题之前,首先要做的事情是搭建一个OpenFoam运行环境.很遗憾的是,OpenFoam的原生开发系统是Linux,因 ...

  9. Spring MVC注解开发入门

    注解式开发初步 常用的两个注解: @Controller:是SpringMVC中最常用的注解,它可以帮助定义当前类为一个Spring管理的bean,同时指定该类是一个控制器,可以用来接受请求.标识当前 ...

  10. CYQ.Data V5 分布式缓存Redis应用开发及实现算法原理介绍

    前言: 自从CYQ.Data框架出了数据库读写分离.分布式缓存MemCache.自动缓存等大功能之后,就进入了频繁的细节打磨优化阶段. 从以下的更新列表就可以看出来了,3个月更新了100条次功能: 3 ...