javascript检测基本类型值或引用类型值的类型方法
首先javascript的数据类型分为两种数据类型:基本数据数据类型和引用数据类型
基本数据类型:Number,String,Boolean,Undefined,Null。原始值,是简单的数据段,可按值访问,直接操作保存在变量中的实际值
引用数据类型:Object,Array,Function,Date,RegExp,单体内置对象(Math,window(客户端才有的全局对象),global(服务端才有的全局对象))。引用值,是保存在栈内存中的对象,是有多个值构成的对象,与其他语言不同的是:你不可以直接访问堆内存空间中的位置和操作堆内存空间,只能操作对象在堆内存中的引用地址
我在这列举了3种方法,使用console.log()逐一打印出来,一目了然
第1种方法,使用typeof检测:
console.log(typeof 1); //number
console.log(typeof "1"); //string
console.log(typeof true); //boolean
console.log(typeof undefined); //undefined
console.log(typeof null); //object console.log(typeof {}); //object
console.log(typeof []); //object
console.log(typeof function() {}); //function
console.log(typeof new Date()); //object
console.log(typeof new RegExp()); //object
console.log(typeof Math); //object
console.log(typeof window); //object(客户端的全局对象,否则undefined)
console.log(typeof global); //object(服务端的全局对象,否则undefined)
第2种方法:使用instanceof检测:
console.log(1 instanceof Number); //false
console.log("1" instanceof String); //false
console.log(true instanceof Boolean); //false
// console.log(undefined instanceof Undefined); //报错,因为Undefined不存在
// console.log(null instanceof Null); //报错,因为Null不存在 console.log({} instanceof Object); //true
console.log([] instanceof Array); //true,也属于Object类型
console.log(function() {} instanceof Function); //true,也属于Object类型
console.log(new Date() instanceof Date); //true,也属于Object类型
console.log(new RegExp() instanceof RegExp); //true,也属于Object类型
第3种方法:使用Object.prototype.toString().call(x)检测:
console.log(Object.prototype.toString.call(1)); //[object Number]
console.log(Object.prototype.toString.call("1")); //[object String]
console.log(Object.prototype.toString.call(true)); //[object Boolean]
console.log(Object.prototype.toString.call(undefined)); //[object Undefined]
console.log(Object.prototype.toString.call(null)); //[object Null] console.log(Object.prototype.toString.call({})); //[object Object]
console.log(Object.prototype.toString.call([])); //[object Array]
console.log(Object.prototype.toString.call(function(){})); //[object Function]
console.log(Object.prototype.toString.call(new Date())); //[object Date]
console.log(Object.prototype.toString.call(new RegExp())); //[object RegExp] console.log(Object.prototype.toString.call(Math)); //[object Math]
console.log(Object.prototype.toString.call(window)); //[object window](客户端的全局对象,否则报错)
// console.log(Object.prototype.toString.call(global)); //[object global](服务端的全局对象,否则报错) console.log(window.JSON && Object.prototype.toString.call(JSON)); // [object JSON]
      function getType(obj){
        let str = Object.prototype.toString.call(obj); // 检测基本类型值,引用类型值的类型
        let map = {
          '[object Boolean]': 'boolean',
          '[object Number]': 'number',
          '[object String]': 'string',
          '[object Function]': 'function',
          '[object Array]': 'array',
          '[object Date]': 'date',
          '[object RegExp]': 'regExp',
          '[object Undefined]': 'unfefined',
          '[object Null]': 'null',
          '[object Object]': 'object'
        };
        if(obj instanceof Element){
          return 'element';
        }
        return map[str];
      }
      console.log("string"); // string
javascript检测基本类型值或引用类型值的类型方法的更多相关文章
- 关于基本类型值和引用类型值以及Vue官方API的array.$remove(reference)
		
今天又是孟哥解惑. 数组里的元素也是指向内存地址么? 这个要分情况的. 无论a[0],a[2]在什么地方,只要其值是基本类型值,就是值的比较,只要其值是引用类型(对象),就是内存地址的比较. Vue官 ...
 - 【javascript】详解变量,值,类型和宿主对象
		
前言 我眼中的<javascript高级程序设计> 和<你不知道的javascript>是这样的:如果<javascript高级程序设计>是本教科书的话, < ...
 - JavaScript中定义变量和存储值的类型判断
		
以严谨的语法表示作为前提 首先变量被定义,然后给变量赋予一定的值,变量真正的作用就是存储值 变量的定义和赋值 变量的定义: var a 使用关键字var+变量名表示定义一个变量 a 变量的赋值: va ...
 - javascript中封装获取样式属性值的兼容方法
		
function getStyle(obj, attr) { if (window.getComputedStyle) { return window.getComputedStyle(obj, nu ...
 - JavaScript基本类型值与引用类型值
		
前言 JS变量可以用来保存两种类型的值:基本类型值和引用类型值.基本类型的值源自一下5种基本数据类型:Underfined.Null.Boolean.Number和String. 基本类型值和引用类型 ...
 - JavaScript引用类型和基本类型的区别
		
JavaScript变量可以用来保存的两种类型的值:基本类型值和引用类型值. 基本类型值有5种类型:undefined,null,boolean,number,string 引用类型值有两种类型:函数 ...
 - 【JavaScript】基本类型和引用类型的值、引用类型
		
一.前言 接着上一篇继续记笔记 二.内容 动态的属性 var person = new Object(); person.name = "Nicholas&qu ...
 - Javascript之基本类型和引用类型
		
ECMAScript变量可能包含两种不同数据类型的值:基本类型值和引用类型值,基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象. 在将一个值赋给变量时,解析器必须确定这个值是基本 ...
 - [转]javascript中基本类型和引用类型的区别分析
		
基本类型和引用类型 ECMAScript包含两个不同类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段:引用类型值指由多个值构成的对象.当我们把变量赋值给一个变量时,解析器首先要做的就是确 ...
 
随机推荐
- Thinkphp5.0 的Model模型
			
Thinkphp5.0 的Model模型 新建user模型User.php: <?php namespace app\index\model; use think\Model; class Us ...
 - [运维]ELK实现日志监控告警
			
https://blog.csdn.net/yeweiouyang/article/details/54948846
 - [bzoj1112][POI2008]砖块Klo_非旋转Treap
			
砖块Klo bzoj-1112 POI-2008 题目大意:$N$柱砖,希望有连续$K$柱的高度是一样的. 你可以选择以下两个动作 1:从某柱砖的顶端拿一块砖出来,丢掉不要了. 2:从仓库中拿出一块砖 ...
 - 更新数据库中数据时出现: Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column  To disable safe mode, toggle the option in Preferences 问题
			
使用workbench在数据库中更新数据时报错: You are using safe update mode and you tried to update a table without a WH ...
 - JSP的会话(Session)跟踪
			
以下内容引用自http://wiki.jikexueyuan.com/project/jsp/session-tracking.html: 会话(Session) HTTP是一个“无状态”协议,这意味 ...
 - LTTNG 使用
			
http://lttng.org/docs/#doc-channel http://www.cnblogs.com/suncoolcat/p/3366045.html http://blog.csdn ...
 - 玩转iOS开发 - 消息推送
			
消息推送
 - zabbix学习系列之QQ消息报警
			
安装依赖包 环境 Zabbix: 3.2 OS:Centos 安装依赖包 yum install lrzsz chrony gcc gcc-c++ git openssl-devel perl-Ext ...
 - AHCI IDE
			
AHCI模式性能好 IDE模式,提高约20%,使用Windows 7 系统,AHCI 模式是最佳选择,特别是对SSD硬盘IDE是为XP的兼容性,RAID 模式是要有两块以上硬盘才能实现AHCI模式装的 ...
 - Android和MVC
			
Activity和Android的mvc模式 http://blog.csdn.net/dengshengjin2234/article/details/8502097 //android涉及到的 ...