美文网首页
javascript 中类的概念

javascript 中类的概念

作者: 戈志刚 | 来源:发表于2017-01-23 15:57 被阅读0次

编写和维护复杂的Javascipt代码,必须使用模块化策略。目前,业界的主流做法是采用"面向对象编程"。因此,Javascript如何实现面向对象编程,就成了一个热门课题。
麻烦的是,Javascipt语法不支持class,导致传统的面向对象编程方法无法直接使用。(当然ES6已经支持class),可以还是有一部分前端工作人员在现有的工作环境上无法使用ES6标准

下面代码本人使用的一段定义类的方法,代码不长,但很实用,希望能帮助到想摆脱javascript代码一多就乱成一坨的同学们
/**
 * 封装类方法
 * @methodOf Clazz.prototype
 */
var Clazz = function() {};
/**
 * [给基类的原型赋值一个方法 当作类的构造器]
 * @return {[Object]} [description]
 */
Clazz.prototype.construct = function() {};
/**
 * 创建类
 * @example
 * var MyClass = Clazz.extend({
 *   //构造器,new时执行
 *   construct: function(myParam){
 *     // 编写你的代码逻辑
 *   }
 * });
 *
 * 继承类
 * var MySubClass = MyClass.extend({
 *   construct: function(myParam){
 *     // 使用这个来调用父类的构造函数
 *     arguments.callee.$.construct.apply(this, arguments);
 *     // 编写你的代码逻辑
 *   }
 * });
 */
Clazz.extend = function(def) {
    var classDef = function() {
        if (arguments[0] !== Clazz) { this.construct.apply(this, arguments); }
    };
    var proto = new this(Clazz);
    var superClass = this.prototype;
    for (var n in def) {
        var item = def[n];
        if (item instanceof Function) item.$ = superClass;
        proto[n] = item;
    }
    classDef.prototype = proto;
    //给这个新类相同的静态扩展方法
    classDef.extend = this.extend;
    return classDef;
};

//========使用实例=========
var MyClass = Clazz.extend({
    construct: function(options){
        this.name = 'MyClass ';
        this.myClassName = 'myClassName ';
    },
    getName: function(){
        return this.name;
    },
    setName: function(name){
        if(name) this.name = name;
    }
});
//继承MyClass 类
var SubClass1 = MyClass .extend({
    construct: function(){
        //未调用父类的构造函数
        this.name = 'SubClass ';
    }
});
//继承MyClass 类
var SubClass2 = MyClass .extend({
    construct: function(){
        //调用父类构造函数
        arguments.callee.$.construct.apply(this, arguments);
        this.name = 'SubClass ';
    }
});

var myClass = new MyClass();
var subClass1 = new SubClass1();
var subClass2 = new SubClass2();

console.log(myClass.getName());     //MyClass 
console.log(myClass.myClassName);   //myClassName

console.log(subClass1.getName());   //SubClass1
console.log(subClass1.myClassName); //undefined

console.log(subClass2.getName());   //SubClass2
console.log(subClass2.myClassName); //myClassName

相关文章

  • javascript 中类的概念

    编写和维护复杂的Javascipt代码,必须使用模块化策略。目前,业界的主流做法是采用"面向对象编程"。因此,Ja...

  • 对JavaScript原型的理解

    JavaScript中是没有类的概念的,有的只是原型和对象。 在说原型之前先说说JavaScript中对象的三种类...

  • 类的概念 虽然 JavaScript 中有类的概念,但是可能大多数 JavaScript 程序员并不是非常熟悉类,...

  • JS中定义对象的几种方式

    JavaScript中没有类的概念,只有对象。在JavaScript中定义对象可以采用以下几种方式:1.基于已有对...

  • 原型与原型链详解

    前言 与大部分面向对象语言不同,JavaScript中并没有引入类(class)的概念,JavaScript并非通...

  • 原型和原型链

    与大部分面向对象语言不同,JavaScript中并没有引入类(class)的概念,但JavaScript仍然大量地...

  • 原型与原型链

    与大部分面向对象语言不同,JavaScript中并没有引入类(class)的概念,但JavaScript仍然大量地...

  • TypeScript进阶(类)

    类 传统方法中,JavaScript 通过构造函数实现类的概念,通过原型链实现继承。而在 ES6 中,我们终于迎来...

  • 对JavaScript原型链的理解

    原型是什么? 在Java中,对象会从类中继承属性,方法等,但JavaScript中并没有类的概念,JavaScri...

  • mongoose Api CRUD操作返回结果总结梳理

    大体概念 mongoose 中的Model是 由 Schema 编译来的构造函数,类似于JavaScript中的类...

网友评论

      本文标题:javascript 中类的概念

      本文链接:https://www.haomeiwen.com/subject/tjpabttx.html