`
alex_gao
  • 浏览: 80969 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Extjs源码——extend

 
阅读更多

Extjs的extend方法是框架本身的一个基础方法,用于形成所有组件之间的继承结构。如果要理解extend方法实现,必须要理解javascript面向对象基础(可参考此文)。

先写一个extend方法具体应用的例子:

Person = function(atts){

	if(atts){
		this.id = atts.id;
		this.name = atts.name;
		this.age  = atts.age;
	}
	
};

Person.prototype.sayName = function(){
	alert(this.name);
};

Programmer = Ext.extend(Person,{
	language : null,
	constructor : function(atts){
		this.language = atts.language;
		Programmer.superclass.constructor.call(this,atts);
		this.name +='&';
	},
	sayLan : function(){
		alert(this.language);
	},
	sayName : function(){
		alert('My name is: ' + this.name);
	}
});

new Person({
	id : '1',
	name : 'empty',
	age : 26
}).sayName();
var programer = new Programmer({
	id : '2',
	name : 'alex',
	age : 26,
	language : 'javascript'
});
programer.sayName();
programer.sayLan();

 这是对extend方法一个简单的应用,实现了person和programmer的继承,同时实现了对属性的扩展、父类属性的修改、方法的重写、方法的扩展。

重点需要关注supperclass、constructor属性。同时,在constructor的call方法之后有一句this.name +='&';,如果放在call方法之前就起不到修改name属性的效果。

 

以下为对Extjs中extend方法加了注解之后的源码。

/**
 * 创建一个属性拷贝的方法,用于设置子类的override方法
 * @param {} o
 */
var io = function(o){
    for(var m in o){
        this[m] = o[m];
    }
};
var oc = Object.prototype.constructor;

return function(sb, sp, overrides){
	/**
	 * 判断sp是否是一个对象,如果是对象,这表示只有两个参数,其中第二参数为需要覆盖的属性或方法。
	 * 将sb转化为构造方法。
	 */
    if(Ext.isObject(sp)){
        overrides = sp;
        sp = sb;
        sb = overrides.constructor != oc ? overrides.constructor : function(){sp.apply(this, arguments);};
    }
    var F = function(){},
        sbp,
        spp = sp.prototype;

    F.prototype = spp;
    /**
     * 实现设置sb的prototype为sp,这里通过一个构造方法为空的F类进行赋值,很妙
     */
    sbp = sb.prototype = new F();
    /**
     * 将子类的构造方法设置到子类的prototype的constructor。
     */
    sbp.constructor=sb;
    /**
     * 设置子类superclass属性为父类的prototype
     */
    sb.superclass=spp;
    /**
     * 设置父类prototype的constructor
     */
    if(spp.constructor == oc){
        spp.constructor=sp;
    }
    /**
     * 设置子类的override方法
     */
    sb.override = function(o){
        Ext.override(sb, o);
    };
    
    /**
     * 子类的prototype的superclass赋值为父类的prototype,superclass还有个简写supr
     *  不知道为什么?
     */
    sbp.superclass = sbp.supr = (function(){
        return spp;
    });
    /**
     * 设置子类的prototype的override方法
     */
    sbp.override = io;
    /**
     * 实现属性和方法的重写
     */
    Ext.override(sb, overrides);
    /**
     * 设置子类的extend方法
     */
    sb.extend = function(o){return Ext.extend(sb, o);};
    return sb;
};
 阅读源码时可以理解部分逻辑,但由于javascript功底有限,有些处理方式还是不知所以然。
分享到:
评论

相关推荐

    ASP.NET源码——ResviewCRM的ExtJS页面程序.zip

    ASP.NET源码——ResviewCRM的ExtJS页面程序.zip

    JSP源码——ExtJS 2.2 开源网络硬盘系统_dogdisk.zip

    【标题】"JSP源码——ExtJS 2.2 开源网络硬盘系统_dogdisk.zip" 提供的是一个基于JSP技术,并使用了ExtJS 2.2框架的开源网络存储系统的源代码。这个系统可能允许用户进行文件的上传、下载、管理,以及实现其他与云...

    ExtJs源码

    extjs 源码,有兴趣的可以学习下

    JSP信息办公类实例开发源码——ExtJS 图书管理系统.zip

    【标题】"JSP信息办公类实例开发源码——ExtJS 图书管理系统"是一个基于Java Server Pages(JSP)技术的Web应用实例,利用了ExtJS框架来构建一个高效的图书管理系统。这个系统的设计目的是为了帮助图书馆或其他图书...

    extjs 源码

    这个源码包不仅包含了EXTJS 3.0的核心库,还提供了相关的文档和代码示例,这对于开发者深入理解EXTJS的工作原理、学习如何自定义组件以及优化应用性能是非常有价值的。 首先,EXTJS 3.0的核心库包含了大量的UI组件...

    ExtJS源码分析与开发实例宝典4.pdf

    这个是《ExtJS源码分析与开发实例宝典》高清版本,是本人花钱买来的,所以分享给大家,希望大家喜欢,由于本人一次只能上传60M大的文件(试了好多次,每次都上传到99%就不动了,还以为csdn在后台审核内容呢,害我电脑...

    ExtJS源码分析与开发实例宝典2.pdf

    这个是《ExtJS源码分析与开发实例宝典》高清版本,是本人花钱买来的,所以分享给大家,希望大家喜欢,由于本人一次只能上传60M大的文件(试了好多次,每次都上传到99%就不动了,还以为csdn在后台审核内容呢,害我电脑...

    ExtJS源码分析与开发实例宝典0.pdf

    这个是《ExtJS源码分析与开发实例宝典》高清版本,是本人花钱买来的,所以分享给大家,希望大家喜欢,由于本人一次只能上传60M大的文件(试了好多次,每次都上传到99%就不动了,还以为csdn在后台审核内容呢,害我电脑...

    ExtJS源码分析与开发实例宝典1.pdf

    这个是《ExtJS源码分析与开发实例宝典》高清版本,是本人花钱买来的,所以分享给大家,希望大家喜欢,由于本人一次只能上传60M大的文件(试了好多次,每次都上传到99%就不动了,还以为csdn在后台审核内容呢,害我电脑...

    JSP源码——[信息办公]ExtJS 2.2 图书管理系统_bmsh.zip

    【JSP源码——[信息办公]ExtJS 2.2 图书管理系统_bmsh.zip】是一个基于JavaServer Pages(JSP)技术开发的信息办公系统,主要用于图书管理。这个系统利用了ExtJS 2.2框架,它是一个强大的JavaScript库,用于构建富...

    ASP.NET源码——[博客空间]ExtJs单用户Blog系统后台源码.zip

    【ASP.NET 源码详解——基于 ExtJS 的单用户 Blog 系统后台】 ASP.NET 是微软公司开发的一种用于构建 Web 应用程序的框架,它集成了 .NET Framework 和 Web 开发工具,使得开发者可以使用 C# 或 VB.NET 等语言进行 ...

    ExtJS源码分析与开发实例宝典(1)——1

    ext 学习资料 内部学习使用。

    ExtJS源码分析与开发实例宝典

    资源名称:Ext JS源码分析与开发实例宝典内容简介:本书全面系统地剖析了ExtJS 3.0的架构设计原理。通过对源码的“抽丝剥茧”,读者可以掌握Ext JS架构的精妙,从原理层面用活Ext JS。此外,本书还提出了大量的解决...

    ExtJS3.0 源码分析与开发实例宝典

    ExtJS3.0 源码分析与开发实例宝典

    extjs源码及API

    extjs下载 extjs源码 extjsApi,全部包括在这里面

    EXTJS4自学手册

    EXTJS4自学手册——EXT文件目录,本地加载文档,命名规范 EXTJS4自学手册——EXT基本方法、属性(onReady、define、create) EXTJS4自学手册——EXT基本方法、属性(apply、applyIf、constructor) EXTJS4自学手册...

    extJS myeclipse源码示例

    extJS myeclipse源码示例

    深入浅出extjs 源码

    《深入浅出ExtJS源码》是一本专为IT专业人士准备的深度解析ExtJS框架源码的书籍。作者徐会生、何启伟和康爱媛以其丰富的编程经验和深入的理解,将复杂的ExtJS源码剖析得清晰易懂,旨在帮助读者深入理解这个强大的...

Global site tag (gtag.js) - Google Analytics