zoukankan      html  css  js  c++  java
  • Extjs使用extend(js继承)

    注:抄<深入浅出Extjs>书

    传统的js实现继承操作为:

    一:定义一个父类

    var BaseClass = function(){

      //.....

    };

    BaseClass.prototype.someMethod = function(){

       //.....

    };

    BaseClass.prototype.overridenMethod = function(){

       //....

    }

    为BaseClass定义两个函数someMethod 和overridenMethod ,,然后定义一个subClass子类,可以直接从BaseClass中继承所有的属性和函数,

    var subClass = function(){

        BaseClass.call(this);

    };

    subClass.prototype = new BaseClass();

    subClass.prototype.newMethod = function(){

       //...

    };

    subClass.prototype.overridenMethod  = function(){

       //...

    }

    在上面的代码中,subClass的构造函数首先调用BaseClass的构造函数初始化数据,然后通过subClass.prototype = new BaseClass();这条语句让subClass类获得BaseClass中的所有属性和函数。这样就实现了继承。在此之后我们就可以操作subClass的prototype,为子类添加新的函数或者覆写父类的同名函数。

    在EXT中使用Ext.extend()函数实现继承功能的方法:

    var subClass = function(){

        subClass.superclass.costructor.call(this);

    };

    Ext.extend(subClass, BaseClass,{

        newMethod: function(){

         //...

       },

       overridenMethod  : function(){ 

         //....

       }

    });

    在Ext.extend()函数通过 subClass.superclass.costructor.call(this);就可以直接调用父类的构造函数。这个函数的第一个参数总是this, 以确保父类的构造函数在子类的作用域里工作。

    如果父类的构造函数需要传入参数,我们也就可以将所需要的参数直接传给它,如:

    subClass.superclass.costructor.call(this, config);

    这样我们就得到了一个继承了父类的所有属性和函数的子类。

  • 相关阅读:
    C#连接各种数据库的方法
    C#中MDI窗体的一些设置
    Winform子窗体刷新父窗体
    MDI窗体应用程序
    C# 窗体间传值方法大汇总
    mdi父窗体如何向子窗体发送数据
    DataGridView 清空原数据
    js call回调的this指向问题
    sass进阶 @if @else if @else @for循环
    sass的加减乘除
  • 原文地址:https://www.cnblogs.com/KimhillZhang/p/2396725.html
Copyright © 2011-2022 走看看