js常用判断数据类型方法以及优缺点 以及 instanceof 原理实现

这篇具有很好参考价值的文章主要介绍了js常用判断数据类型方法以及优缺点 以及 instanceof 原理实现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.typeof操作符:

使用typeof操作符可以判断一个值的数据类型。它返回一个表示数据类型的字符串。

  • 优点:typeof 操作符是一种简单、快速的方式来判断基本数据类型。它返回的结果是一个字符串,可以直接用于条件判断。
  • 缺点:对于引用类型(除了函数)的判断结果都是'object',无法细分具体的引用类型。同时,对于null的判断结果也是’object’,不能准确判断null。
var arr = [1, 2, 3];
var obj = { name: 'zhangsan', age: 19 };
var fn = function(){}

console.log(typeof 24);  // 输出: 'number'
console.log(typeof 'Hello');  // 输出: 'string'
console.log(typeof true); // 输出: 'boolean'
console.log(typeof arr);  // 输出: 'object'
console.log(typeof obj);  // 输出: 'object'
console.log(typeof fn);  // 输出: 'function'
console.log(typeof null); //输出: 'object'

2.instanceof操作符:

使用instanceof操作符可以判断一个对象是否是某个构造函数的实例。

instanceof 是 JavaScript 的一个操作符,用于检查某个对象是否是某个特定类的实例

  • 优点:instanceof操作符可以判断一个对象是否是某个构造函数的实例,可以用于自定义构造函数的判断。它可以处理继承关系,如果对象是某个构造函数的子类实例,也会返回true。
  • 缺点:instanceof操作符只能判断对象是否是特定构造函数的实例,不能判断基本数据类型的数据。此外,如果在多个窗口或框架中使用,可能会导致不准确的结果。
// 手写一个方法实现 instanceof 原理
const instanceofs = (target, obj) => {
	let p = target;
	while(p){
		if(p == obj.prototype){
			return true
		}
		p = p.__proto__  
		// 循环p的原型,如果不相等,最后p.__proto__.__proto__.__proto__ 结果为null ,就会跳出循环
	}
	return false;
} 
console.log(instanceofs([1,2.3], Object) ) // true

3.constructor属性:

每个对象都有一个constructor属性,它引用了创建该对象的构造函数

  • 优点:constructor属性是每个对象都具有的属性,可以直接使用它来判断对象的构造函数。它适用于大多数对象类型的判断,包括基本数据类型和引用类型
  • 缺点:如果对象的constructor属性被修改或重写,判断结果可能不准确。此外,在继承关系中,可能会出现构造函数不一致的情况
var num = 42;
var str = 'Hello';
var bool = true;
var arr = [1, 2, 3];
var obj = { name: 'John', age: 25 };

console.log(num.constructor === Number);   // 输出: true
console.log(str.constructor === String);   // 输出: true
console.log(bool.constructor === Boolean); // 输出: true
console.log(arr.constructor === Array);    // 输出: true
console.log(obj.constructor === Object);   // 输出: true

4.Object.prototype.toString方法:

使用Object.prototype.toString方法可以返回一个表示对象类型的字符串。文章来源地址https://www.toymoban.com/news/detail-664732.html

  • 优点:Object.prototype.toString方法返回的字符串包含了更详细的信息,可以准确判断对象的数据类型。它适用于所有的数据类型,包括基本数据类型和引用类型。
  • 缺点:调用Object.prototype.toString方法需要使用call方法来绑定this对象,使用起来相对复杂一些。
var num = 42;
var str = 'Hello';
var bool = true;
var arr = [1, 2, 3];
var obj = { name: 'John', age: 25 };

console.log(Object.prototype.toString.call(num));   // 输出: '[object Number]'
console.log(Object.prototype.toString.call(str));   // 输出: '[object String]'
console.log(Object.prototype.toString.call(bool));  // 输出: '[object Boolean]'
console.log(Object.prototype.toString.call(arr));   // 输出: '[object Array]'
console.log(Object.prototype.toString.call(obj));   // 输出: '[object Object]'

到了这里,关于js常用判断数据类型方法以及优缺点 以及 instanceof 原理实现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • js数据类型和判断数据类型的方法

    js数据类型 1.基本数据类型(原始类型): number boolean string null:空对象 undefined:未定义 Symbol(es6新增): 表示独一无二的值。 为了解决对象实例新的方法与已有方法名冲突问题 。 每个从 Symbol() 返回的 symbol 值都是唯一的,从而确保每个属性的名字都是独一无二的。 Sym

    2024年02月07日
    浏览(44)
  • 使用js编写一个函数判断所有数据类型的通用方法

    一、判断数据类型的方法 1、typeof 在 JavaScript 里使用 typeof 来判断数据类型,只能区分基本类型,即 “number”,”string”,”undefined”,”boolean”,”object” 五种。 对于数组、对象来说,其关系错综复杂,使用 typeof 都会统一返回 “object” 字符串。 要想区别对象、数组单

    2024年02月22日
    浏览(50)
  • 云计算(概念,模式、服务类型、应用案例,优缺点)

    云计算是一种利用网络(通常是互联网)提供按需计算资源和服务的模式。在这种模型中,资源、软件和信息通过网络提供给计算机和其他设备,通常是以服务的形式。云计算使得用户能够远程访问服务器、存储、网络和应用程序等计算资源,而不需要拥有或直接管理物理硬

    2024年02月03日
    浏览(52)
  • js寄⽣组合继承和优缺点

    在JavaScript中,寄生组合继承是一种实现继承的方法,它结合了原型链继承和构造函数链继承的优点。以下是一个简单的寄生组合继承的例子: function Parent() {   this.name = \\\'Parent\\\'; } Parent.prototype.getName = function() {   return this.name; }; function Child() {   Parent.call(this); // 调用父类构造函

    2024年01月25日
    浏览(42)
  • restFul的优缺点以及思考

    在HTTP中,我们要通过 URL 进行资源的定位 比如: 要取 id=888 的用户信息,我们就向/user/{id} 这个路径发送请求, 要取 id=888 的用户的订单列表,我们就向/user/{id}/orders 这个路径发送请求 在HTTP 中,DELETE、PUT、GET请求应该是幂等的,而POST 则不是幂等的。所谓“幂等”指的是:对于

    2024年02月10日
    浏览(46)
  • .NET的发展历程以及优缺点

    .NET是由微软推出的一个开放的编程平台,它支持多种编程语言和操作系统,旨在为开发人员提供一种快速、灵活、高效的应用程序开发方法。下面是.NET的发展历史: .NET Framework 1.0(2002年):.NET Framework 1.0 在2002年发布,这是.NET平台的第一个版本,包含了基本的API和运行时环

    2024年02月03日
    浏览(48)
  • 浅谈 iframe的优缺点以及使用场景

    提示:以下是本篇文章正文内容 iframe 是嵌入式框架,是 HTML框架 ,还是一个 内联元素 ,iframe元素会创建包含另一个文档的内联框架(行内框架),说白了就是,iframe用来在页面嵌入其他的页面。 通常我们使用iframe直接在页面嵌套iframe标签指定src就可以了。 iframe能够把嵌入

    2024年02月05日
    浏览(64)
  • TCP/UDP区别以及优缺点详解

    TCP/IP协议的具体含义 TCP协议位于传输层,IP协议位于网络层。 TCP/IP协议很多情况下只是利用IP进行通信时所必须用到的协议群的统称。具体来说,IP或ICMP、TCP和UDP、TELNET或FTP,以及FTTP等都属于TCP/IP协议,有时候也称TCP/IP为网络协议群。 TCP、UDP协议的区别: 注:可从以下几个方

    2024年02月04日
    浏览(58)
  • 四大常用MQ的优缺点和应用场景选择

      官网地址 :http://activemq.apache.org/ - 官网介绍 Apache ActiveMQ是最流行的开源、多协议、基于Java的消息代理。它支持行业标准协议,因此用户可以从多种语言和平台的客户端选择中获益。从JavaScript、C、C++、Python、.NET等多个客户端连接。使用无处不在的AMQP协议集成多平台应用程

    2023年04月22日
    浏览(43)
  • 缓存类型及优缺点:Ehcache、Caffeine、Memcached和Redis的比较

    在Java中,常见的缓存类型包括内存缓存、磁盘缓存和分布式缓存。这些缓存类型在功能和使用方式上有一些区别。 内存缓存:将数据存储在应用程序的内存中,以提高数据的读取速度。常见的内存缓存实现包括HashMap和ConcurrentHashMap等。内存缓存的优点是读写速度快,但容量

    2024年02月05日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包