位置: 编程技术 - 正文

js继承 Base类的源码解析(js常用继承)

编辑:rootadmin
// timestamp: Tue, May :: /* base2.js - copyright , Dean Edwards */ // You know, writing a javascript library is awfully time consuming. //////////////////// BEGIN: CLOSURE //////////////////// // ========================================================================= // base2/Base.js // ========================================================================= // version 1.1 var Base = function(){ // call this method from any other method to invoke that method's ancestor }; Base.prototype = { extend: function(source){ //参数大于一个时 if (arguments.length > 1) { // extending with a name/value pair //获得proto的祖先 var ancestor = this[source]; var value = arguments[1]; //如果value(第二个参数)是function,并且祖先对象存在,在重载函数中调用base时 if (typeof value == "function" && ancestor && /bbaseb/.test(value)) { // get the underlying method var method = value; // override value = function(){ var previous = this.base; this.base = ancestor; //上溯到父类对象 var returnValue = method.apply(this, arguments); this.base = previous; return returnValue; }; value.method = method; value.ancestor = ancestor; } this[source] = value; } else if (source) { // extending with an object literal 用一个对象列表来扩展 var extend = Base.prototype.extend; /** * 1.扩展原型方法和属性 2. */ //如果是扩展属于原型的方法或属性,先遍历其重载Object的3个方法 if (Base._prototyping) { var key, i = 0, members = ["constructor", "toString", "valueOf"]; while (key = members[i++]) { //如果是重载了这些方法 if (source[key] != Object.prototype[key]) { /** * 逐个扩展,用call的原因是要将extend的上下文改为要扩展的源this, * 既是新建对象的父类对象 */ extend.call(this, key, source[key]); } } } else if (typeof this != "function") { // if the object has a customised extend() method then use it extend = this.extend || extend; } // copy each of the source object's properties to this object for (key in source) if (!Object.prototype[key]) { extend.call(this, key, source[key]); } } return this; }, base: Base }; Base.extend = function(_instance, _static){ // subclass /** * Base类原型的扩展别名,将这个当成一个方法调用 */ var extend = Base.prototype.extend; /** * build the prototype,创建原型 * 设置原型标志 */ Base._prototyping = true; /** * 创建一个Base的实例,初始化继承部分 * 继承方式大致还是以下方式 * function A(){} * function B(){ * this.b=[]; * } * A.prototype=new B();//A继承B的所有属性和方法 * 这种继承方式会有一个问题,B中声明的对象(如b)以prototype的形式 * 被A继承之后,prototype只是生成一个指向B中对象的引用,即 * A所有实例会共同享有B中对象(b) * var a1=new A(); * var a2=new A(); * a1.b.push("a"); * a2.b.push("a"); * 此时,a1.b=a2.b=["a","a"], * * Dean Edwards在实现继承的时候,以父类为基础,创建实例, * 利用extend扩展该实例,最后用A.prototype=new B();实现继承 * 但是属性是对象的时候没有做处理, * 还是没有避开上述的继承缺陷 */ var proto=new this; /** * 在这里,不可以用 proto.extend(_instance)代替 */ extend.call(proto, _instance); /** * 类实例属性和方法的原型部分构造完毕,删除标志位 */ delete Base._prototyping; /** * 这里作者运用了适配器的模式,用自定义的构造器生成一个新的类对象 * wrapper/adapter:通过一定的方法,一个对象封装或授权另一个 * 对象来改变它的接口或者行为 */ // create the wrapper for the constructor function /** * 获得构造器的引用 */ var constructor = proto.constructor; /** * 建立klass的Function对象,调用自定义的构造器, klass就是衍生的子类 * 两种情况下,调用此方法: * 1.创建类实例的时候,这时候不是原型构造阶段,执行由extend方法 * 继承的时候设定的构造方法 * 2.当用extend方法衍生子类的时候---new this * 因为下文中klass的属性已经全部获得, * 所以当new完之后,获得所有父类的方法和属性都包含在了 * proto里面了,这时候,在proto的基础上运用prototype的extend方法 * 将此子类的属性和方法添加到proto里面 */ var klass = proto.constructor = function(){ /** * var proto=new this; 调用父类的构造函数,创建一个父类的实例 * new this用完后,函数重定向到子类对象构造方法 */ if (!Base._prototyping) { /** * 当在构造函数中(constructor)调用base方法时, * base方法会调用父类对象的构造函数,这时候会嵌套 * 调用这个代码段,方法得以执行的条件就是this._constructing==true */ if (this._constructing || this.constructor == klass) { // instantiation this._constructing = true; constructor.apply(this, arguments); delete this._constructing; } /** * * 不再向下执行 */ else { // casting var object = arguments[0]; if (object != null) { (object.extend || extend).call(object, proto); } return object; } } }; // build the class interface /** * */ for (var i in Base){ klass[i] = this[i]; } /** * 创建继承链 */ klass.ancestor = this; klass.base = Base.base; klass.prototype = proto; klass.toString = this.toString; /** * 扩展类方法,属性,类似java的static */ extend.call(klass, _static); // class initialisation 如果存在init函数 调用 if (typeof klass.init == "function") klass.init(); return klass; }; // initialise Base = Base.extend({ constructor: function(){ this.extend(arguments[0]); } }, { ancestor: Object, base: Base, implement: function(_interface){ if (typeof _interface == "function") { // if it's a function, call it _interface(this.prototype); } else { // add the interface using the extend() method this.prototype.extend(_interface); } return this; } });

推荐整理分享js继承 Base类的源码解析(js常用继承),希望有所帮助,仅作参考,欢迎阅读内容。

js继承 Base类的源码解析(js常用继承)

文章相关热门搜索词:js继承的三种方法,js 如何继承,js继承的三种方式,js继承模式,js继承函数,js中继承,js继承的三种方法,js继承的三种方式,内容如对您有帮助,希望把文章链接给更多的朋友!

[推荐]javascript 面向对象技术基础教程 结果呢,看了大半天,有了一个大概的了解,细细一回味,好像什么都没懂...这篇文章是参考javascript-thedefinitiveguide,5thedition第7,8,9章而写成的,我也会尽量按

小型js框架veryide.librar源代码 /**CopyrightVeryIDE,-*

JavaScript RegExp方法获取地址栏参数(面向对象) Request={QueryString:function(item){varsvalue=location.search.match(newRegExp('[?&]'+item+'=([^&]*)(&?)','i'));returnsvalue?svalue[1]:svalue;}}varkey=Request.QueryString('key');Request.QueryString

标签: js常用继承

本文链接地址:https://www.jiuchutong.com/biancheng/386459.html 转载请保留说明!

上一篇:Javascript 对象的解释(javascript 对象的this指向)

下一篇:[推荐]javascript 面向对象技术基础教程([推荐]抖音上那些好看的视频和有才的帐号)

  • 增值税税控系统产品及维护服务价格
  • 一个人可以在多家公司任职吗
  • 物业公司收款一般多久
  • 待认证进项税是借方还是贷方
  • 税务未抄报
  • 减免的所得税额怎么入账
  • 出口货物补税申报表
  • 退休人员怎么缴纳城镇居民医保
  • 建筑业的进项税怎么抵扣
  • 计算并分摊本月利润
  • 进项转出发票是否还可以转回抵扣做分录呢?
  • 财政拨款的事业单位有哪些
  • 社保多交了一份怎么办
  • 企业发票入账冲销流程
  • 销项负数发票如何作废
  • 计提年终奖金的会计分录怎么写
  • 增值税进项税额转出是什么意思
  • 公司单独买医保
  • 工会发放员工福利的通知
  • 所得税清算时坏账怎么算
  • 企业残疾人保障金
  • 购入原材料没有发票只有入库单
  • 管理费用怎么记忆
  • 上年度退回来的所得税,怎么做分录
  • 企业计算缴纳的所得税费用
  • win11 zen3
  • macos monterey值得安装吗
  • 期初摊余成本是初始入账价值吗
  • 印花税减半征收优惠政策2023
  • 王者荣耀中哪吒的图片
  • 鸿蒙系统蓝牙耳机声音小怎么办
  • Win11怎么设置屏幕熄灭时间
  • 已付货款没有发票能做支出吗
  • 房地产企业开发成本结转
  • linux中的文件
  • 汇票到期收到款项会计分录
  • 我公司的某供应商英语
  • excel2019冻结
  • 微信网页开发工具
  • 信托融资放在哪个科目
  • Web前端开发知识点总结
  • ai复制命令
  • 管理费用中的福利费有限额吗
  • 织梦官方网站
  • 公司的融资租赁有哪些
  • 临时贷款属于什么会计科目
  • 营业利润是负数什么原因
  • 固定资产出售的收入属于收入吗
  • 接受捐赠后怎么发表感言
  • 要约收购的条件和程序具体包括哪些?
  • 员工社保,个税怎么计算
  • SQL Server SQL Agent服务使用教程小结
  • sql server 自增列设置语句
  • 详解MySQL的limit用法和分页查询语句的性能分析
  • Win8系统Smartscreen筛选器界面变灰无法设置的解决方法
  • win2008server安装qq
  • win7如何查看图片的rgb
  • linux系统中cp命令
  • unix操作指令
  • 一招让你的wifi网速翻倍
  • win7升win8要钱吗
  • win10安装vc++6.0
  • win7如何取消开机启动
  • win8玩游戏
  • cocos2dx4.0教程
  • vs2019怎么用gets
  • extJS中常用的4种Ajax异步提交方式
  • Python win32com 操作Exce的l简单方法(必看)
  • Cocos2dx ParticleEditor粒子编辑器
  • 局域网远程开机与远程唤醒
  • Unity3d-四元数到矩阵的实现
  • unity官方插件
  • jQuery ajax调用后台aspx后台文件的两种常见方法(不是ashx)
  • python约瑟夫问题最高效算法
  • 深圳市税务局陈建新
  • 临沂市国家税务局人员名单
  • 江苏钢厂排名前十
  • 国际税收对经济活动的影响
  • 车船使用税2021
  • 招投标法实施条例是哪一年修正的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设