首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

有没有办法通过查找构造函数来获取类的名称

在JavaScript中,可以通过查找构造函数来获取类的名称。以下是一种常见的方法:

代码语言:txt
复制
function getClassName(obj) {
  if (obj && obj.constructor && obj.constructor.toString) {
    const arr = obj.constructor.toString().match(/function\s*(\w+)/);
    if (arr && arr.length === 2) {
      return arr[1];
    }
  }
  return undefined;
}

这个方法接受一个对象作为参数,并返回该对象所属类的名称。它通过检查对象的构造函数并使用正则表达式来提取类名。

这种方法在以下情况下特别有用:

  1. 当你需要动态地获取对象所属类的名称时。
  2. 当你需要进行对象类型的判断时。

这是一个简单的示例,演示了如何使用这个方法:

代码语言:txt
复制
class Person {
  constructor(name) {
    this.name = name;
  }
}

const person = new Person("John");
console.log(getClassName(person)); // 输出 "Person"

在这个示例中,我们定义了一个名为Person的类,并创建了一个名为person的实例。通过调用getClassName函数并传入person对象,我们可以获取到该对象所属类的名称,即"Person"。

腾讯云提供了一系列云计算相关的产品和服务,其中包括云服务器、云数据库、云存储等。你可以在腾讯云官方网站上找到更多关于这些产品的详细信息和文档。

请注意,本回答仅提供了一种解决方案,并不代表唯一的正确答案。在实际应用中,可能会有其他方法来获取类的名称。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 从EFCore上下文的使用到深入剖析DI的生命周期最后实现自动属性注入

    最近在把自己的一个老项目从Framework迁移到.Net Core 3.0,数据访问这块选择的是EFCore+Mysql。使用EF的话不可避免要和DbContext打交道,在Core中的常规用法一般是:创建一个XXXContext类继承自DbContext,实现一个拥有DbContextOptions参数的构造器,在启动类StartUp中的ConfigureServices方法里调用IServiceCollection的扩展方法AddDbContext,把上下文注入到DI容器中,然后在使用的地方通过构造函数的参数获取实例。OK,没任何毛病,官方示例也都是这么来用的。但是,通过构造函数这种方式来获取上下文实例其实很不方便,比如在Attribute或者静态类中,又或者是系统启动时初始化一些数据,更多的是如下一种场景:

    02

    javascript基础知识

    对象是一个包含相关数据和方法的集合(通常由一些变量和函数组成,我们称之为对象里面的属性和方法)。在其他经典的面向对象的语言中我们并没有办法直接去创建对象,我们都需要先用class这样的关键词创建一个对象模板(被称为类),然后调用类的构造函数去初始化一个对象出来,在类中描述的属性和方法会复制一份到对象中去,然而对于javascript来说,情况并非如此(不像“经典”的面向对象的语言,从构建函数创建的新实例的特征并非全盘复制,而是通过一个叫做原形链的参考链链接过去的,所以这并非真正的实例,严格的讲, JavaScript 在对象间使用和其它语言的共享机制不同,这个后面再讲),我们可以直接创建一个对象而不需要对象模板,创建方法请参考第二节。

    02

    JS【中高级】部分的知识点总结第一篇

    每一个知识点我都会尽可能的讲明白,写一些Demo给你们,就像前面写canvas的时候一样,尽量多写一些有说明性的代码,两个目的,第一个是总结一下,第二个是进行一个记录,也给学习js的过程中比较迷茫的一些提示,这篇文章是属于js中相对中高级的,所以初级的看起来会有一些困难,但是初级的可以直接百度或者看我之前的一些关于js的文章进行学习也是可以的!虽然上面的每一个点都是可以直接单独拿出来写一篇文章的,我也不是没这么计划,只是觉得这样会显的这个知识点好像很难一样,会劝退一部分人,所以就直接一篇文章直接搞定算了,篇幅会比较长,和前面的小程序和canvas一样,因为最近都是写一些总结性质的文章,可能会相对比较繁琐,读的时候可以直接收藏,后面慢慢看!我也会尽量的将每一个模块都分的比较清楚!

    01

    JS【中高级】部分的知识点我帮你们总结好了

    每一个知识点我都会尽可能的讲明白,写一些Demo给你们,就像前面写canvas的时候一样,尽量多写一些有说明性的代码,两个目的,第一个是总结一下,第二个是进行一个记录,也给学习js的过程中比较迷茫的一些提示,这篇文章是属于js中相对中高级的,所以初级的看起来会有一些困难,但是初级的可以直接百度或者看我之前的一些关于js的文章进行学习也是可以的!虽然上面的每一个点都是可以直接单独拿出来写一篇文章的,我也不是没这么计划,只是觉得这样会显的这个知识点好像很难一样,会劝退一部分人,所以就直接一篇文章直接搞定算了,篇幅会比较长,和前面的小程序和canvas一样,因为最近都是写一些总结性质的文章,可能会相对比较繁琐,读的时候可以直接收藏,后面慢慢看!我也会尽量的将每一个模块都分的比较清楚!

    01
    领券