JS中检测数据类型的四种方式及每个方式的优缺点
//1、typeof 用来检测数据类型的运算符
//->typeof value
//->返回值首先是一个字符串,其次里面包含了对应的数据类型,例如:"number"、"string"、"boolean"、"undefined"、"object"、"function"
//->局限性:
//1)typeof null ->"object"
//2)检测的不管是数组还是正则都返回的是"object",所以typeof不能判断一个值是否为数组
//->console.log(typeof typeof typeof [12, 23]);//->"string"
//2、instanceof/constructor
//->检测某一个实例是否属于某一个类
//->我们使用instanceof/constructor可以检测数组和正则了
// console.log([] instanceof Array);//->true
// console.log(/^$/ instanceof RegExp);//->true
// console.log([] instanceof Object);//->true
// console.log([].constructor === Array);//->true
// console.log([].constructor === Object);//->false 我们的constructor可以避免instanceof检测的时候,用Object也是true的问题
// console.log({}.constructor === Object);
//局限性:
//1)用instanceof检测的时候,只要当前的这个类在实例的原型链上(可以通过原型链__proto__找到它),检测出来的结果都是true
// var oDiv = document.getElementById("div1");
// //HTMLDivElement->HTMLElement->Element->Node->EventTarget->Object
// console.log(oDiv instanceof HTMLDivElement);//->true
// console.log(oDiv instanceof Node);//->true
// console.log(oDiv instanceof Object);//->true
//2)基本数据类型的值是不能用instanceof来检测的
//->console.log(1 instanceof Number);//->false
//数组创建的两种方式(对象、正则、函数...)
//->对于引用数据类型来说,我们两种方式创建出来的都是所属类的实例,而且都是对象数据类型的值,是没有区别的
// var ary = [];
// var ary = new Array;
//->对于基本数据类型来说,虽然不管哪一种方式创建出来的都是所属类的一个实例(在类的原型上定义的方法都可以使用),但是字面量方式创建出来的是基本数据类型,而实例方式创建出来的是对象数据类型
// var num1 = 1;
// var num2 = new Number("1");
// console.log(typeof num1,typeof num2);//->"number" "object"
//3)在类的原型继承中,instanceof检测出来的结果其实是不准确的
// function Fn() {}
// var f = new Fn;
// console.log(f instanceof Array);//->false f不是一个数组,它就是一个普通的实例(普通的对象)
//->虽然我们的Fn继承了Array,但是f没有length和数字索引哪些东西,所以f应该不是数组才对,但是用instanceof检测的结果却是true,因为f虽然不是数组,但是在f的原型链上可以找到Array
// function Fn() {
// }
// Fn.prototype = new Array;//->Fn子类继承了Array这个父类中的属性和方法
// var f = new Fn;
// console.log(f instanceof Array);//->true
//3、Object.prototype.toString.call(value) ->找到Object原型上的toString方法,让方法执行,并且让方法中的this变为value(value->就是我们要检测数据类型的值)
//->toString:一个方法,转换为字符串数据类型用的方法
//每一个数据类型所属类的原型上都有toString方法,例如:Number.prototype/String.prototype/Array.prototype/Function.prototype...
//除了Object上的toString,其他类原型上的toString都是把当前的数据值转换为字符串的意思
//->null和undefined比较的特殊:他们所属类Null/Undefined的原型上也有toString,只不过不让我们用而已,不仅如此其实类的原型都给屏蔽了
//->HTML元素对象的toString:虽然它的原型链很长,但是在其它类的原型上都没有toString,只有在最底层Object.prototype这上才有
//var oDiv = document.getElementById("div1");
//oDiv.toString();//->调用的其实也是Object.prototype.toString...
//->alert、document.write这两种输出的方式其实都是把要输出的内容先转换为字符串,然后在输出的
// alert([]);//->""
// alert(true);//->"true"
// alert({});//->这个就要调用Object.prototype上的toString了 ->?
//4、Object.prototype.toString是用来返回对应值的所属类信息的
// var oDiv = document.getElementById("div1");
// var obj = {};
// oDiv.toString();//->"[object HTMLDivElement]"
// obj.toString();//->"[object Object]"
//原理:
//->obj首先找到原型上toString方法,并且让toString执行,toString方法执行的时候,里面的this是obj,同理oDiv.toString(),toString方法中的this是oDiv
//->执行toString方法,返回当前方法中this的数据类型 ->"[object 当前this的直属类]",例如:"[object HTMLDivElement]"/"[object Object]"
//Object.prototype.toString.call(12);//->执行原型上的toString,并且让方法中的this变为12,也就相当于返回的是12的直属类的信息 ->"[object Number]"
//Object.prototype.toString.call("zhufeng");//->"[object String]"
//依此类推:
//"[object Boolean]"/"[object Null]"/"[object Undefined]"/"[object Object]"/"[object Array]"/"[object RegExp]"/"[object Function]"/"[object Math]"/"[object Date]"...
//->所有的数据类型都可以用它来检测,而且非常的精准
//value:要检测数据类型的值 type:判断是否为这个数据类型
// function isType(value, type) {
// var res = Object.prototype.toString.call(value);//-> "[object 直属类]"
// return res === "[object " + type + "]";
//// 98->"[object Array]"
//// 字符串拼接->"[object Array"]"
//// 两个相等了返回true
// }
//优化:->忽略第二个传递进来参数的大小写
// function isType(value, type) {
// var reg = new RegExp("^\\[object " + type + "\\]$", "i");
// return reg.test(Object.prototype.toString.call(value));
// }
// var ary = [];
// var flag = isType(ary, "array");
// console.log(flag);//->true说名是数组,false说明不是数组 ->true
//
// flag = isType(1, "string");
// console.log(flag);//->false
~function () {
var utils = {}, numObj = {
isNum: "Number",
isStr: "String",
isBoo: "Boolean",
isNul: "Null",
isUnd: "Undefined",
isObj: "Object",
isAry: "Array",
isFun: "Function",
isReg: "RegExp",
isDate: "Date"
}, isType = function () {
var outerArg = arguments[0];
return function () {
var innerArg = arguments[0], reg = new RegExp("^\\[object " + outerArg + "\\]$", "i");
return reg.test(Object.prototype.toString.call(innerArg));
}
};
for (var key in numObj) {
if (numObj.hasOwnProperty(key)) {
utils[key] = isType(numObj[key]);
}
}
window.$type = utils;
}();
//console.log($type);
var ary = [];
console.log($type.isAry(ary));//->true
console.log($type.isFun(ary));//->false
JS中检测数据类型的四种方式及每个方式的优缺点的更多相关文章
- JS中检测数据类型的四种方法
1.typeof 用来检测数据类型的运算符->typeof value->返回值首先是一个字符串,其次里面包含了对应的数据类型,例如:"number"."st ...
- js中判断数据类型的四种方法总结
js中判断数据类型的四种方法 前言 在js中,我们经常需要判断数据的类型,那么哪些方法可以用来判断数据的类型呢?哪种方法判断数据类型最准确呢? 我们来一个个分析: 1.typeof typeof是一个 ...
- JS 中检测数组的四种方法
今天和大家分享一下 JS 中检测是不是数组的四种方法,虽然篇幅不长,不过方法应该算是比较全面了. 1. instanceof 方法 instanceof 用于检测一个对象是不是某个类的实例,数组也是一 ...
- JS中检测数据类型的几种方式及优缺点【转】
1.typeof 用来检测数据类型的运算符 typeof value 返回值首先是一个字符串,其次里面包含了对应的数据类型,例如:"number"."string&quo ...
- JS中检测数据类型的几种方式及优缺点
1.typeof 用来检测数据类型的运算符 typeof value 返回值首先是一个字符串,其次里面包含了对应的数据类型,例如:"number"."string&quo ...
- js中检测数据类型的几种方式
1.typeof 一元运算符,用来检测数据类型.只可以检测number,string,boolean,object,function,undefined. 对于基本数据类型是没有问题的,但是遇到引用数 ...
- 判断js中的数据类型的几种方法
判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...
- 转:判断js中的数据类型的几种方法
判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...
- JS中判断数据类型的几种方法
1⃣️首先我们来了解一下js中的数据类型 1.基本数据类型:Undefined.Null.Boolean.Number.String(值类型) 2.复杂数据类型:Object(引用类型) (值类型和引 ...
随机推荐
- SQL按照指定顺序对字段进行排序
SqlServer按照指定顺序对字段进行排序 问题如下,在SqlServer有一个这样的SQL查询 SELECT *FROM ProductWHERE ID IN ( 12490, 12494, 12 ...
- XPath 定位----光荣之路
被测试网页的HMTL代码 <html> <body> <div id="div1"> <input name="div1inpu ...
- windows下不打开浏览器访问网页的方法
我们打开电脑,大多时候都是打开浏览器在上网.这都是通过浏览器来实现的,然而windows下有没有办法不通过浏览器也可以像linux那样达到访问网页的目的呢?这当然少不了批处理或者VBScript.然而 ...
- CStringUtf8ToUnicode
CString CStringUtf8ToUnicode( CString Utf8 ) { int wLen = 0; CString strUnicode; LPSTR pBufChar = NU ...
- Java for LeetCode 141 Linked List Cycle
Given a linked list, determine if it has a cycle in it. Follow up: Can you solve it without using ex ...
- 项目总结(二)--- CocoaPods的简单介绍与使用
先谈下,我们为什么要使用CocoaPods,它能为我们做什么吧. 所有开发过iOS应用的小伙伴们都知道,在整个项目中,第三方库的引用必不可少(特别感谢那些优秀第三方开源库的作者,给我们提供了多大的便捷 ...
- CodeForces - 424B (贪心算法)
Megacity Time Limit: 2000MS Memory Limit: 262144KB 64bit IO Format: %I64d & %I64u Submit Sta ...
- 开源混淆工具ProGuard配置详解及配置实例
ProGuard的作用: 1.创建紧凑的代码文档是为了更快的网络传输,快速装载和更小的内存占用. 2.创建的程序和程序库很难使用反向工程. 3.所以它能删除来自源文件中的没有调用的代码 4.充分利 ...
- Mysql 5.6.17-win64.zip配置
第一大步:下载. a.俗话说:“巧妇难为无米之炊”嘛!我这里用的是 ZIP Archive 版的,win7 64位的机器支持这个,所以我建议都用这个.因为这个简单嘛,而且还干净. 地址见图 拉倒最下面 ...
- JAVA基础学习之 Map集合、集合框架工具类Collections,Arrays、可变参数、List和Set集合框架什么时候使用等(4)
package com.itcast.test20140113; import java.util.ArrayList; import java.util.Arrays; import java.ut ...