CSS=function(key,val){
var $=this.style;
if(val!==undefined){
$[key]=val;
return this;
}
if ($[key])return $[key];
if (this.currentStyle) return this.currentStyle[key]
if (document.defaultView && document.defaultView.getComputedStyle){
key = key.replace(/([A-Z])/g,"-$1").toLowerCase();
var V = document.defaultView.getComputedStyle(this,"");
return V && s.getPropertyValue(key);
}
return null;
}
<script>
// 目标函数
function base(){
alert('原函数')
}
// 装饰器
Decorator={
beginList:[]//前置列表
,endList:[]//后置列表
,append:function (fn){
this.endList.push(fn);
}
,before:function (fn){
this.beginList.splice(0,0,fn)
}
,wrap:function (fn/* 待装饰的函数 */){
var $=this,$1=[],$2=[];
// 拷贝两个列表内容放到闭包
for (var i=0;i<$.beginList.length;i++ )
$1[i]=$.beginList[i];
for (var i=0;i<$.endList.length;i++ )
$2[i]=$.endList[i];
try{
// 返回装饰完毕的函数
return function (){
for (var i=0;i<$1.length;i++ )
$1[i]();
if(typeof fn == 'function')fn();
for (var i=0;i<$2.length;i++ )
$2[i]();
}
}finally{
// 用finally技巧在返回后清空缓存的列表,以备下次使用
this.beginList.length=this.endList.length=0;
}
}
}
Decorator.append(function (){
alert('第1个追加函数')
});
Decorator.append(function (){
alert('第2个追加函数')
});
Decorator.before(function (){
alert('第1个前插函数')
});
Decorator.before(function (){
alert('第2个前插函数')
});
v=Decorator.wrap(base);
alert('装饰器的列表长度现在为: '+Decorator.endList.length)
v()
</script>
posted on 2009-02-26 17:38
汪杰 阅读(230)
评论(0) 编辑 收藏 引用 所属分类:
javascript