一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Js中的類式繼承

  類式繼承對于大部分開發者來說都已經熟悉,只要有了帶方法(method)的類(class)就可以把他們實例化(instantiate)為對象.

  下面就有一個簡單的方法來模擬類式繼承.代碼清單如下:

  <script>

    //輔助函數 定義
    Function.prototype.method = function( name,func ){
        
this.prototype[name] = func;
         
return this;    
    }
    
    
//實現函數
    Function.method('inherits'function(parent){
        
//記錄我們目前所在父層次的級數
        var depth = 0;
        
//繼承父對象的方法
        var proto = this.prototype = new parent();
        
        
//特權函數
        this.method('uber'function uber(name){
            
var func;
            
var ret;
            
var v = parent.prototype;
            
//如果我們已經在某個 'uber' 函數之內
            if(depth){
                
for (var i=d; i>0;i+=1) {
                    v 
= v.constructor.prototype;
                };
                
//從該prototype中或得函數
                func = v[name];
            }
            
else{
                
//從prototype獲得要執行的函數
                func = prototype[name];
                
                
//如果此函數屬于當前的prototype
                if( func == this[name]){
                    
//則改為調用父對象的prototype
                    func = v[name];
                }
            }
            
//記錄我們在繼承堆棧中所在位置的級數
            depth += 1;
            
            
//
            ret = func.apply(this,Array.prototype.slice.apply(arguments,[1]));
            
            
//恢復繼承堆棧
            depth -= 1;
            
            
return ret;
        });
        
return this;
    })
    
//只繼承父對象特定函數的函數
    Function.method('swiss',function(parent){
        
for (var i=1; i<arguments.length; i++) {
            
var name = arguments[i];
            
//將此方法導入this對象的prototype
            this.prototype[name] = parent.prototype[name];
        };
        
return this;
    })
        
function Person( name ){
        
this.name = name;
    }
    
    
//實現的例子
    Person.method('getName'function(){
        
return name;
    })
    
function  User( name, password ){
        
this.name = name;
        
this.password = password; 
    }
    User.inherits( Person );
</script>

it知識庫Js中的類式繼承,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品日韩欧美一区二区三区 | 国产在线观看第一页 | 狠狠色做五月深爱婷婷 | 精品一区二区三区在线视频 | 91精品日本久久久久久牛牛 | 天天色天 | 美女黄色免费看 | 91精品一区二区三区在线 | 久久91综合国产91久久精品 | 全色黄大色大片免费久久老太 | 激性欧美激情在线播放16页 | 国产成人乱码一区二区三区 | 伊人狼人综合 | 2021国内精品久久久久影院 | 亚洲成年网站 | 五月婷婷激情网 | 男人女人黄 色一视频一级 男人女人无遮掩免费视频 男人女人做刺激视频免费 男人让女人爽的免费视频 男人日女人的免费视频 | 高清国产一区二区三区 | 国产精品人伦久久 | 日韩 在线视频精品 | 亚洲欧美一区二区久久 | 国产一区二区三区免费 | 久久亚洲网站 | www色.com | 老司机51精品视频在线观看 | 51国产偷自视频区视频手机播器 | 色在线网站 | 久久中文娱乐网 | 欧美地区一二三区 | 五月婷婷导航 | 中国成人在线视频 | 九九综合视频 | 91网站网站网站在线 | 欧美另类极品videosbest视 | 91精品国产高清久久久久久 | 污污网站免费入口链接 | 国产精品短视频 | 欧美黑人粗硬大在线看 | 国产精品综合视频 | 成人在线视频网 | 久久不色|