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

給Function做的OOP擴展

 更新時間:2009年05月07日 15:07:22   作者:  
自編框架Megami的一部分……現(xiàn)在發(fā)現(xiàn)自己實在太宅了…… 文件中出現(xiàn)的名字請對號入座……
復(fù)制代碼 代碼如下:

// 下面是OOP用的方法
// 這樣很猥瑣……因為JS并不是OOP語言……
// 但偉大的伍迷指引我們來這么干
// Belldandy會保佑用這些方法來OOP的人的……
Function.prototype.inherits = function(base){
//派生關(guān)系,保留了prototype
//只支持單派生
this.prototype = new base();
return this;
}
Function.prototype.create = function(){
//類的創(chuàng)建器,和用new等價
//JS不支持在構(gòu)造器用call和apply,所以……
//Belldandy啊,感謝你告訴我怎么解決這個問題啊……
var _args = [];
for(i=0;i<arguments.length;i++) _args.push('arguments['+i+']');

return eval('new this('+_args.join(',')+')'); //eval都用上了……Bell啊,下次給個好點的主意吧……
}
Function.prototype.pin = function(pinner,args){
// 注冊服務(wù),或者叫“pin”服務(wù)
// EventManager就可以這么干
// 你也可以認為實現(xiàn)了有默認實現(xiàn)的接口……

// 例如,pin EventManager就可以這樣:Class.pin(core.WvwntManager)
args = args || [];
pinner.apply(this.prototype,args);
return this;
}
Function.prototype.method = function(name, f) { //添加方法,高效
if (!(f instanceof Function)) throw new Error('方法綁定無效,得到類型'+typeof f+';期待為function');
this.prototype[name] = f;
return this
}
Function.prototype.property = function(name, localName, getter, setter) { //添加屬性,可自定getter、setter
if (!name || !name instanceof String) throw new EnvironmentException('定義屬性時,屬性名沒有定義,或者不是字符串');
if (!localName || !localName instanceof String) localName = '_local_' + name;
if(getter instanceof Function) {
this.prototype['_belldandy_get_'+name] = getter;
}
if(setter instanceof Function){
this.prototype['_belldandy_set_'+name] = setter;
}
this.prototype[name] = new Function("value , force"," \
if (!value && !force) { \
if (!this['"+'_belldandy_get_'+name+"'] || !this['"+'_belldandy_get_'+name+"'] instanceof Function) \
return this['"+localName+"']; /* 沒有設(shè)置getter時 */\
else \
return this['"+'_belldandy_get_'+name+"'].call(this); \
} else { \
if (!this['"+'_belldandy_set_'+name+"'] || !this['"+'_belldandy_set_'+name+"'] instanceof Function) \
this['"+localName+"'] = value; \
else\
this['"+'_belldandy_set_'+name+"'].call(this, value); \
return this\
}") //Belldandy啊,饒恕我吧,雖然這樣不產(chǎn)生閉包
return this;
}
Function.prototype.static = function(name,value){ //靜態(tài)特征,包括屬性和方法
this[name] = value;
return this;
}

使用效果如下:
復(fù)制代碼 代碼如下:

function foo() { };
foo
.property('a', '_a')
.property('b', '_b', function() { return this._b + '.' })
.method('f', function() { dwn(this.a()) });
function bar(x,y){this.x = x;this.y = y;};
with(bar){
inherits(foo)
method('g',function(){dwn(this.a()+'-'+this.b())})
}

var f = new foo();
f.a(1);
f.b(2);
dwn(f.a());
dwn(f.b());
f.f();
b = bar.create(1,2);
b.a(4);
b.b(5);
dwn(b.x+','+b.y);
b.g();
//dwn自己參閱月影的書

相關(guān)文章

  • JavaScript中的子窗口與父窗口的互相調(diào)用問題

    JavaScript中的子窗口與父窗口的互相調(diào)用問題

    本文給大家介紹了JavaScript中的子窗口與父窗口的互相調(diào)用問題,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-02-02
  • js動態(tài)往表格的td中添加圖片并注冊事件

    js動態(tài)往表格的td中添加圖片并注冊事件

    這篇文章主要介紹了使用js動態(tài)往表格的td中添加圖片并注冊事件,需要的朋友可以參考下
    2014-06-06
  • js實現(xiàn)網(wǎng)頁版貪吃蛇游戲

    js實現(xiàn)網(wǎng)頁版貪吃蛇游戲

    這篇文章主要為大家詳細介紹了js實現(xiàn)網(wǎng)頁版貪吃蛇游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • javascript中的數(shù)據(jù)類型檢測方法詳解

    javascript中的數(shù)據(jù)類型檢測方法詳解

    這篇文章主要介紹了javascript中的數(shù)據(jù)類型檢測方法,結(jié)合實例形式分析了javascript數(shù)據(jù)類型并總結(jié)分析了常見的數(shù)據(jù)類型檢測操作技巧,需要的朋友可以參考下
    2019-08-08
  • 網(wǎng)頁上的Javascript編輯器和代碼格式化

    網(wǎng)頁上的Javascript編輯器和代碼格式化

    因為我們的項目可以通過編寫腳本(javascript)進行功能擴展,所以為了方便現(xiàn)場實施人員,所以突發(fā)奇想想在網(wǎng)頁上(系統(tǒng)是B/S的)提供一個javascript的編輯器。
    2010-04-04
  • 注意 JavaScript 中 RegExp 對象的 test 方法

    注意 JavaScript 中 RegExp 對象的 test 方法

    注意 JavaScript 中 RegExp 對象的 test 方法...
    2007-01-01
  • 深入淺出理解javaScript原型鏈

    深入淺出理解javaScript原型鏈

    這篇文章主要介紹了對javaScript原型鏈的理解,以實例形式對javaScript原型鏈的概念及相關(guān)使用技巧做了較為淺顯易懂的分析,需要的朋友可以參考下
    2015-05-05
  • web前端開發(fā)也需要日志

    web前端開發(fā)也需要日志

    web前端開發(fā)過程中調(diào)試是一個不可避免的過程,我們有眾多的瀏覽器可供選擇,但是如果您要調(diào)試的平臺瀏覽器不是那么先進呢
    2010-12-12
  • JavaScript奇技淫巧44招【實用】

    JavaScript奇技淫巧44招【實用】

    JavaScript是一個絕冠全球的編程語言,可用于Web開發(fā)、移動應(yīng)用開發(fā)(PhoneGap、Appcelerator)、服務(wù)器端開發(fā)(Node.js和Wakanda)等等。本文主要介紹JavaScript應(yīng)用的一些小技巧。
    2016-12-12
  • 微信小程序版本機制和storage如何平滑兼容詳解

    微信小程序版本機制和storage如何平滑兼容詳解

    這篇文章主要給大家介紹了關(guān)于微信小程序版本機制和storage如何平滑兼容的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-12-12

最新評論