一区二区久久-一区二区三区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视频| 色网网站 | 激情亚洲 | 欧美亚洲激情在线 | 两性午夜刺激性视频 | 美女特黄 | 最新精品在线视频 | 国产日韩欧美一区二区三区综合 | 久视频在线观看久视频 | 久久2017| 国产福利免费看 | 久久婷婷伊人 | 欧洲精品码一区二区三区免费看 | 国产麻豆| 中文字幕国产在线 | 国产福利小视频在线播放观看 | 97天天干| 四虎影视色费永久在线观看 | 天天射天天干天天色 | 加勒比精品 | 超人碰碰碰人人成碰人 | 国产精品国产午夜免费福利看 | 伊人狠狠色j香婷婷综合 | 国产视频一二三区 | 国产精品久久亚洲一区二区 | 日本欧美一区二区三区高清 | 天天做天天添天天谢 | 在线免费视频一区二区 | 91麻精品国产91久久久久 | 高清在线观看免费 | 亚洲婷婷综合色高清在线 | 国产精品第 | 九九九网站 | 五月天久草 | 亚洲天堂婷婷 | 五月婷婷丁香综合 | 国产亚洲视频在线播放大全 | 久久国产乱子伦精品免费一 | 欧美精品亚洲二区 | 一区二区三区免费高清视频 | 亚洲激情综合 |