欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS仿Base.js實現的繼承示例

 更新時間:2017年04月07日 11:27:58   作者:風之約  
這篇文章主要介紹了JS仿Base.js實現的繼承,結合具體實例形式分析了javascript擴展操作及面向對象程序設計相關實現技巧,需要的朋友可以參考下

本文實例講述了JS仿Base.js實現的繼承。分享給大家供大家參考,具體如下:

var Klass = function() {};
Klass.extendClass = (function() {
  var F = function() {};
  return function(C, P) {
    F.prototype = P.prototype;
    C.prototype = new F();
    C.uper = P.prototype;
    C.prototype.constructor = C;
  };
})();
Klass.extend = function(props) {
  var _slice = Array.prototype.slice;
  var Glass = function() {
    /*if (Glass.uper && Glass.uper.hasOwnProperty("init")) {
      Glass.uper.init.apply(this, _slice.call(arguments))
    }*/
    if (Glass.prototype.hasOwnProperty("init")) {
      Glass.prototype.init.apply(this, _slice.call(arguments));
    }
  };
  Klass.extendClass(Glass, this);
  Glass.extend = this.extend;
  for (var key in props) {
    if (props.hasOwnProperty(key)) {
      Glass.prototype[key] = props[key];
    }
  }
  return Glass;
};

example:

var A = Klass.extend({
    init: function(name) {
      this.name = name;
      console.log('A constructor is running!');
    },
    getName: function() {
      return this.name;
    }
});
var B = A.extend({
    init: function(name) {
      this.name = name;
      console.log('B constructor is running!');
    },
    getName: function() {
      return this.name;
    },
    a: 'b'
});
var C = B.extend({
    init: function(name) {
      console.log('C constructor is running!');
    },
    c: 'c',
    getName: function() {
      var name = C.uper.getName.call(this);
      return 'Hi, I\'m' + this.name;
    }
});
var c1 = new C('zlf');
console.log(c1.getName());

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • JavaScript實現動畫打開半透明提示層的方法

    JavaScript實現動畫打開半透明提示層的方法

    這篇文章主要介紹了JavaScript實現動畫打開半透明提示層的方法,涉及javascript操作DOM的相關技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • JS實現多張圖片預覽同步上傳功能

    JS實現多張圖片預覽同步上傳功能

    這篇文章主要介紹了JS實現多張圖片預覽同步上傳功能的相關資料,需要的朋友可以參考下
    2017-06-06
  • Bootstrap圖片輪播組件Carousel使用方法詳解

    Bootstrap圖片輪播組件Carousel使用方法詳解

    這篇文章主要為大家詳細介紹了Bootstrap圖片輪播組件Carousel使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • js在ie下打開對話窗口的方法小結

    js在ie下打開對話窗口的方法小結

    下面小編就為大家?guī)硪黄猨s在ie下打開對話窗口的方法小結。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • ES7中利用Await減少回調嵌套的方法詳解

    ES7中利用Await減少回調嵌套的方法詳解

    大家都知道在ES7中有了標準的回調函數嵌套的解決方案,新增了 async/await兩個關鍵詞,所以這篇文章主要給大家介紹了關于Javascript中如何利用Await減少回調嵌套的相關資料,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2017-11-11
  • 全解跨域請求問題處理方法及分析

    全解跨域請求問題處理方法及分析

    這篇文章主要為大家介紹了全解跨域請求問題處理方法及分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪<BR>
    2023-07-07
  • 微信小程序地圖實現展示線路

    微信小程序地圖實現展示線路

    這篇文章主要為大家詳細介紹了微信小程序地圖實現展示線路,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • js 轉json格式的字符串為對象或數組(前后臺)的方法

    js 轉json格式的字符串為對象或數組(前后臺)的方法

    下面小編就為大家?guī)硪黄猨s 轉json格式的字符串為對象或數組(前后臺)的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • 前端算法題解leetcode114二叉樹展開為鏈表

    前端算法題解leetcode114二叉樹展開為鏈表

    這篇文章主要為大家介紹了前端算法題解leetcode114二叉樹展開為鏈表,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • JS插件overlib用法實例詳解

    JS插件overlib用法實例詳解

    這篇文章主要介紹了overlib用法,結合實例較為詳細的分析了JavaScript插件overlib的相關使用技巧,需要的朋友可以參考下
    2015-12-12

最新評論