ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript AOP は、javascript スキルを使用するのに便利な ajax コールバック関数を実装します

JavaScript AOP は、javascript スキルを使用するのに便利な ajax コールバック関数を実装します

WBOY
リリース: 2016-05-16 18:15:50
オリジナル
1179 人が閲覧しました
复制代码代码如下:

function actAsDecorator(object) {
object.setupDecoratorFor = function(メソッド) {
if (! (オブジェクト内の 'original_' メソッド) ) {
オブジェクト['original_' メソッド] = オブジェクト[メソッド];
オブジェクト['before_' メソッド] = [ ];
オブジェクト['after_' メソッド] = [ ];
オブジェクト[メソッド] = function() {
var i;
var b = this['before_' メソッド];
var a = this['after_' メソッド];
var rv;
for (i = 0; i b[i].call(this, argument);
}
rv = this['original_' メソッド].apply(this, argument);
for (i = 0; i a[i].call(this, argument);
}
rv を返します。
}
}
};
object.before = function(method, f) {
object.setupDecoratorFor(method);
オブジェクト['before_' メソッド].unshift(f);
};
object.after = function(method, f) {
object.setupDecoratorFor(method);
オブジェクト['after_' メソッド].push(f);
};
}
/**

を呼び出しています*/
function Test(){
this.say1 = function(s){
alert(s);
}
this.say2 = function(s){
alert(s);
}
}
var t = new Test();
actsAsDecorator(t);
t.before("say1",beforeHander);
t.after("say2",afterHander);
テスト();
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート