要实现类似Java中getClass()方法的对象类名获取方式,可以使用JavaScript中的Object.prototype.toString方法。这个方法可以返回一个表示当前对象的字符串,其中包含了对象的类型信息。
要实现类似Java中getClass()方法的对象类名获取方式,可以使用JavaScript中的Object.prototype.toString方法。这个方法可以返回一个表示当前对象的字符串,其中包含了对象的类型信息。
下面是实现该方法的详细步骤:
- 定义一个全局函数,比如叫做getClass,接收一个对象作为参数。
function getClass(obj) {
// 实现代码
}
- 调用Object.prototype.toString方法,获取到对象的类型字符串。
function getClass(obj) {
var typeStr = Object.prototype.toString.call(obj);
}
- 从类型字符串中提取出类名部分,返回给调用者。
function getClass(obj) {
var typeStr = Object.prototype.toString.call(obj);
return typeStr.slice(8, -1);
}
这里的slice函数是用来截取字符串的方法,8和-1是参数,表示从第8个字符开始截取,一直截取到倒数第一个字符(不包含倒数第一个字符)。
下面两个示例分别演示了如何使用这个函数:
var a = [];
getClass(a); // 输出 "Array"
function Foo() {}
var b = new Foo();
getClass(b); // 输出 "Foo"
当传入一个数组时,getClass函数返回的是数组的类名 "Array"。当传入一个自定义类型的对象时,比如上面的Foo实例,getClass函数则返回 "Foo"。
除了对象类型的获取,我们还可以使用该函数获取其他类型的类名。例如:
getClass(null); // 输出 "Null"
getClass(undefined); // 输出 "Undefined"
getClass(123); // 输出 "Number"
getClass('abc'); // 输出 "String"
总结起来,利用Object.prototype.toString方法,我们可以轻松地实现一个类似Java中getClass()的方法,来获取JavaScript中各种类型的类名信息。
本文标题为:javascript实现类似java中getClass()得到对象类名的方法


基础教程推荐
- 简单实现ajax获取跨域数据 2023-02-14
- VUE界面设计(Ⅰ)——Login界面 2023-10-08
- jQuery Ajax方式上传文件的方法 2023-01-20
- 从入门到入土Java EE(八)——jsp,html,servlet连接SQL server数据库的登录注册界面 2023-10-25
- 带你了解CSS基础知识,样式 2022-11-23
- vue3+webpack项目搭建 2023-10-08
- vue3.0之Teleport 2023-10-08
- 微信小程序自动化部署的全过程 2022-08-31
- vue-vuex-mutations的基本使用 2023-10-08
- Jquery Ajax请求方法小结(值得收藏) 2022-10-17