返回顶部
首页 > 资讯 > 精选 >JavaScript中怎么检测数据类型
  • 944
分享到

JavaScript中怎么检测数据类型

2023-07-06 04:07:58 944人浏览 薄情痞子
摘要

本篇内容介绍了“javascript中怎么检测数据类型”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!检测数据类型1:typeof其返回结果都

本篇内容介绍了“javascript中怎么检测数据类型”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

检测数据类型1:typeof

其返回结果都是字符串,字符串中包含了对应的数据类型 number/string/boolean/undefined/symbol/object/function

局限性:检测null返回的是object,检测其他如数组、正则等特殊对象时,返回的结果都是object,无法区分具体类型。

console.log(typeof 12); //=>"number"console.log(typeof null); //=>"object"console.log(typeof []); //=>"object"console.log(typeof /^$/); //=>"object"

检测数据类型2:instanceof

用于检测某个实例是否属于这个类,其检测的底层机制是所有出现在其原型链上的类,检测结果都是true

局限性:由于可以基于__proto__或者prototype改动原型链的动向,所以基于instanceof检测出来的结果并不一定是准确的。而基本数据类型的值,连对象都不是,更没有__proto__,虽说也是所属类的实例,在js中也可以调取所属类原型上的方法,但是instanceof是不认的。

console.log(12 instanceof Number); //falseconsole.log(new Number(12) instanceof Number); //trueconsole.log([] instanceof Array); //trueconsole.log([] instanceof Object); //truefunction Fn() {}Fn.prototype.__proto__ = Array.prototype;let f = new Fn();console.log(f instanceof Array); //true

检测数据类型3:constructor

这是实例所属类原型上的属性,指向的是类本身,但其也是可以进行修改,与instanceof类似。

let arr = [];console.log(arr.constructor); //ƒ Array() { [native code] }console.log(arr.constructor === Array); //truelet n=12;console.log(n.constructor === Number); //true

检测数据类型4:Object.prototype.toString.call([value]) / ({}).toString.call([value])  

该方法不是用来转换为字符串的,而是返回当前实例所属类的信息,其返回结果的格式为[object 所属类信息],即[object Object/Array/RegExp/Date/Function/Null/Undefined/Number/String/Boolean/Symbol...]

这种方式基本上没有什么局限性,是检测数据类型相对来说最准确的方式。

console.log(Object.prototype.toString.call(12)); //[object Number]console.log(Object.prototype.toString.call([])); //[object Array]console.log(Object.prototype.toString.call({})); //[object Object]function fn () {}console.log(({}).toString.call(fn)); //[object Function]console.log(({}).toString.call(/^$/)); //[object RegExp]console.log(({}).toString.call(new Date)); //[object Date]

虽然检测数据类型4相对来说最好,但格式稍微繁琐一些,是不是可以想办法封装一个方法,输出结果类似于typeof那种,直接输出如number、date、regexp这种,确实是有的。

var class2type = {};var toString = class2type.toString; //=>Object.prototype.toStringvar hasOwn = class2type.hasOwnProperty; //=>Object.prototype.hasOwnPropertyvar fnToString = hasOwn.toString; //=>Function.prototype.toStringvar ObjectFunctionString = fnToString.call(Object); //=>Object.toString() =>"function Object() { [native code] }""Boolean Number String Function Array Date RegExp Object Error Symbol".split(" ").forEach(function anonymous(item) {    class2type["[object " + item + "]"] = item.toLowerCase();});console.log(class2type);function toType(obj) {    //=>obj may be null / undefined    //=>return "null"/"undefined"    if (obj == null) {        return obj + "";    }    return typeof obj === "object" || typeof obj === "function" ? class2type[toString.call(obj)] || "object" : typeof obj;}

这是Jquery中用来检测数据的方法,可以达到我们说的需求。

“JavaScript中怎么检测数据类型”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: JavaScript中怎么检测数据类型

本文链接: https://lsjlt.com/news/357652.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript中怎么检测数据类型
    本篇内容介绍了“JavaScript中怎么检测数据类型”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!检测数据类型1:typeof其返回结果都...
    99+
    2023-07-06
  • JavaScript中检测数据类型的四种方法
    目录1. typeof2. instanceof3. constructor(构造函数)4. Object.prototype.toString.call()前言:在介绍检测数据类型...
    99+
    2024-04-02
  • JavaScript怎么检测文件的类型
    这篇文章主要介绍JavaScript怎么检测文件的类型,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在日常工作中,文件上传是一个很常见的功能。在某些情况下,我们希望能限制文件上传的类型,比如限制只能上传 PNG 格式...
    99+
    2023-06-15
  • JavaScript中检测数据类型的四种方法总结
    目录检测数据类型1:typeof检测数据类型2:instanceof检测数据类型3:constructor检测数据类型4:Object.prototype.toString.call...
    99+
    2023-05-16
    JavaScript检测数据类型方法 JavaScript检测数据类型 JavaScript数据类型
  • JavaScript数据类型检测实现方法详解
    目录一、typeof二、instanceof三、Object.prototype.toString.call()面试问题一、typeof 优点:能快速判断基本数据类型,除了 Null...
    99+
    2022-11-13
    JavaScript数据类型检测 JS数据类型检测
  • JavaScript数据类型检测功能如何实现
    本文小编为大家详细介绍“JavaScript数据类型检测功能如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript数据类型检测功能如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、t...
    99+
    2023-07-04
  • JavaScript中检测数据类型的四种方法分别是什么
    这期内容当中小编将会给大家带来有关JavaScript中检测数据类型的四种方法分别是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言:在介绍检测数据类型的方法之前,先说说JavaScript中数据类...
    99+
    2023-06-26
  • JavaScript之类型检测的案例
    这篇文章主要介绍了JavaScript之类型检测的案例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、typeoftypeof:操作符返回一个字符串,表示未经计算的操作数的...
    99+
    2023-06-07
  • javascript怎么检测小数
    这篇文章主要介绍了javascript怎么检测小数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 javascr...
    99+
    2024-04-02
  • JavaScript 检测文件的类型的方法
    目录一、如何查看图片的二进制数据二、如何区分图片的类型三、如何检测图片的类型3.1 定义 readBuffer 函数3.2 定义 check 函数3.3 检测 PNG 图片类型我们会...
    99+
    2024-04-02
  • javascript怎么转数据类型
    这篇文章将为大家详细讲解有关javascript怎么转数据类型,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 javascript转数据类型的...
    99+
    2024-04-02
  • oracle数据类型怎么测试
    如何测试 oracle 数据类型:创建测试表,指定要测试的数据类型的列。插入包含不同值的数据,以测试范围和边界条件。查询数据并检查数据类型是否按预期工作。验证查询结果中显示的数据类型与指...
    99+
    2024-05-21
    oracle
  • Javascript ES6中数据类型Symbol怎么用
    这篇文章给大家分享的是有关Javascript ES6中数据类型Symbol怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。介绍Symbol 是一种特殊的、不可变的数据类型,...
    99+
    2024-04-02
  • JavaScript中的数据类型怎么使用
    这篇文章主要介绍“JavaScript中的数据类型怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript中的数据类型怎么使用”文章能帮助大家解决问题。一、基本数据类型(原始值类型...
    99+
    2023-06-30
  • JavaScript类型检测的方法实例教程
    前言 JavaScript是web前端广泛应用的语言之一,在网页应用制作、脚本制作、小程序等诸多领域具有不可替代的的地位。笔者学习了一端时间的前端,颇感JS知识点的繁碎,故将学习到...
    99+
    2024-04-02
  • 如何使用JavaScript 检测文件的类型
    这篇文章将为大家详细讲解有关如何使用JavaScript 检测文件的类型,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、如何查看图片的二进制数据要查看图片对应的二进制数据,我们可以借助一些...
    99+
    2023-06-15
  • js中基于数据类型检测的方式有哪些
    这篇文章主要为大家展示了“js中基于数据类型检测的方式有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“js中基于数据类型检测的方式有哪些”这篇文章吧。1、t...
    99+
    2024-04-02
  • javaScript中一些常见的数据类型检查校验
    目录前言常见的几种数据校验方式typeof操作符instanceofconstructorcall && applyObject.prototype.toString...
    99+
    2024-04-02
  • JavaScript怎么判断数据类型
    小编给大家分享一下JavaScript怎么判断数据类型,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!判断数据类型使用 Object.prototype.toStr...
    99+
    2023-06-27
  • javascript什么数据类型
    Javascript是一种动态类型语言,因此它的数据类型非常灵活。在Javascript中,数据类型可以是基本类型或对象类型,本文将介绍Javascript中各种数据类型。一、基本数据类型字符串(String)字符串是Javascript中...
    99+
    2023-05-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作