获取JavaScript用户自定义类的类名称的代码

物种多样

物种多样

2016-02-19 10:27

下面,图老师小编带您去了解一下获取JavaScript用户自定义类的类名称的代码,生活就是不断的发现新事物,get新技能~
我们知道,虽然JavaScript是基于对象(object-based)的语言。但是使用其原形(prototype)特性,我们完全可以实现十分sexy的OO编成框架,这个可以看看经典论坛的文章'基本上实现 javascript 的 OOP (0423版)'。

    不过虽然我们实现了'类'这种概念,可是JavaScript的脚本系统却仍然是不认账的。我们并没有办法使用脚本系统中的typeof方法获取自定义类的类型,比如'类'JSClass定义如下:

 function JSClass()
 {
    this.Attribute1 = null;
    this.Attribute2 = null;

    this.Method1 = function()
    {
       // ...
    };

    this.Method2 = function()
    {
       // ...
    };

    this.toString = function()
    {
       return '[class JSClass]';
    };
 }
    我们生成一个它的实例:var jsclass = new JSClass();
    可是如果使用alert(typeof(jsclass)),我们只能得到'object'。而是用alert(jsclass),我们却得到'[class JSClass]',这是对象实例默认调用toString()方法的结果。当然我们可以把类名称"JSClass"使用toString()方法来返回,不过这种依赖手动type来保证正确性的方法并不时很理想。

    于是我们从类定义本身去想办法,由于JavaScript中的对象(Object)默认都实现了toString()方法,而且函数对象(Function)的toString()方法就是返回该函数的定义本身,这样我们就可以通过处理类定义来获取类名了。

    我们通过对象实例的constructor属性,可以获取其构造函数的定义,而构造函数的名字也就是JavaScript用户自定义类的类名称。对于上面的例子,执行 var strFun = jaclass.constructor.toString(),strFun就是构造函数的原始语句定义(和上面语句块内容相同)的字符串。我们从strFun中取出"函数名"(类名)就行了,可是这里需要注意。Function类的实例执行toString()时并不会格式化代码,比如我们把JSClass的构造函数写成如下格式:

function
   JSClass
   (
   )
{
   this.Attribute1 = null;
   this.Attribute2 = null;
   // ...
}
    执行toString()后的strFun里代码也是这个样子。

    所以获取类名还需要特别的小心,方法__typeof__的代码如下:

 function __typeof__(objClass)
 {
     if ( objClass && objClass.constructor )
     {
         var strFun = objClass.constructor.toString();
         var className = strFun.substr(0, strFun.indexOf('('));
         className = className.replace('function', '');
         return className.replace(/(^s*)|(s*$)/ig, '');  
     }
     return typeof(objClass);
 }

    示例:

script language="javascript"
alert(__typeof__(jsclass));
alert(__typeof__(JSClass));
alert(__typeof__(1));
alert(__typeof__([]));
alert(__typeof__({}));
/script
    结果分别为:"JSClass", "Function", "Number", "Array"和"Object"。

    这里需要注意两个地方,一是:jsclass和JSClass的区别,jsclass是类实例,而JSClass返回类型却是Function哦;第二个是如果是系统类型,使用typeof得到的类型都是小写的,比如number、array或objece啥的,而使用__typeof__获得的类型名称是和其类型名匹配的,首字母都大写。
展开更多 50%)
分享

猜你喜欢

获取JavaScript用户自定义类的类名称的代码

Web开发
获取JavaScript用户自定义类的类名称的代码

ExtJS中如何扩展自定义的类

Web开发 ExtJs
ExtJS中如何扩展自定义的类

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

javaScript自定义绑定

Web开发
javaScript自定义绑定

使用静态类实现JSP自定义标签

Web开发
使用静态类实现JSP自定义标签

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

FlashMX2004建立自定义类package

flash教程
FlashMX2004建立自定义类package

javascript定义类和实例化类

Web开发
javascript定义类和实例化类

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

该行已经属于另一个表 的解决方法

该行已经属于另一个表 的解决方法

Javascript之文件操作

Javascript之文件操作
下拉加载更多内容 ↓