コード:
プログラムコード
/*
カプレット広告コールの最初のパラメータは ID、2 番目のパラメータは画像、3 番目のパラメータは広告とトップの間の距離です。
4 番目のパラメータは左と右を表し (true は左を表し、false は右を表します)、5 番目のパラメータはカプレット アドバタイズメントの幅を表します。
*/
new float_ad("ad_l","<img src='/u/info_img/2009-06/11/2009Cherry.gif' />",50,true,64);
new float_ad("ad_r","<img src='/u/info_img/2009-06/11/2009Cherry.gif' />",50,false,64)
;
フローティング広告呼び出しの最初のパラメータの URL は、フローティング広告の画像 URL アドレス (必須)、ページ URL へのリンク、代替画像プロンプト テキスト、画像の幅 (オプション、デフォルトは 120)、および高さ画像の高さ (オプション、デフォルトは 120)
2 番目のパラメータはフローティング広告の初期位置を表し、パラメータ left と top で指定します。値が小さいほどフローティング速度が速くなります。
*/
new move_ad({url:" /u/info_img/2009-06/11/2009Cherry.gif",link:"http://jzyouth.org.cn/html/zixun/zuixingonggao/2009327/zxgg47926848.html",alt : "「2009 中国大連国際桜祭り」ボランティア募集のお知らせ, width: 200, height: 200}, {left: 40, top: 160}, 20);
// コアコード
関数 $(要素){
if(arguments.length>1){
for(var i=0,elements=[],length=arguments.length;i<length;i++)
elements.push($(arguments[i]));
要素を返します。
}
if(要素の種類=="文字列")
document.getElementById(要素)を返します;
それ以外
戻り要素;
}
Function.prototype.bind=関数(オブジェクト){
var メソッド = this;
戻り関数(){
メソッド.apply(オブジェクト,引数);
}
}
varClass={
作成:関数(){
戻り関数(){
this.initialize.apply(this,arguments);
}
}
}
Object.extend=function(宛先,リソース){
for(リソース内の var プロパティ){
宛先[プロパティ]=リソース[プロパティ];
}
返送先。
}
//カップル広告http://www.knowsky.com/article.asp?typeid=36
var float_ad=Class.create();
float_ad.prototype={
初期化:function(id,content,top,left,width){
document.write('<div id='+id+' style="position:absolute;">'+content+'</div>');
this.id=$(id);
this.top=トップ;
if(!!左){
this.id.style.left="8px";
}それ以外{
this.id.style.left=(document.documentElement.clientWidth-width-8)+"px";
window.onresize=function(){
this.id.style.left=(document.documentElement.clientWidth-width-8)+"px";
}.bind(this);
}
this.id.style.top=top+"px";
this.interId=setInterval(this.scroll.bind(this),20);
}、
スクロール:関数(){
this.stmnStartPoint = parseInt(this.id.style.top, 10);
this.stmnEndPoint =document.documentElement.scrollTop+ this.top;
if(navigator.userAgent.indexOf("Chrome")>0){
this.stmnEndPoint=document.body.scrollTop+this.top;
}
if ( this.stmnStartPoint != this.stmnEndPoint ) {
this.stmnScrollAmount = Math.ceil( Math.abs( this.stmnEndPoint - this.stmnStartPoint ) / 15 );
this.id.style.top = parseInt(this.id.style.top, 10) + ( ( this.stmnEndPoint<this.stmnStartPoint ) ? -this.stmnScrollAmount : this.stmnScrollAmount )+"px";
}
}
}
//フローティング広告クラス
var move_ad=Class.create();
move_ad.prototype={
初期化:関数(imgOption、initPosition、遅延){
this.imgOptions=Object.extend({url:"",link:"",alt:"",width:120,height:120},imgOption||{});
this.adPosition=Object.extend({left:40,top:120},initPosition||{});
this.delay =遅延;
this.step = 1;
this.herizonFlag=true;
this.verticleFlag=true;
this.id="ad_move_sg";
var vHtmlString="<div id='"+this.id+"' style='position:absolute; left:"+this.adPosition.left+"px; top:"+this.adPosition.top+"px; width:" +this.imgOptions.width+"px;";
vHtmlString+=" height:"+this.imgOptions.height+"px; z-index:10;'><a href='"+this.imgOptions.link+"' target='_blank' title='"+this.imgOptions .alt+"><img src='"+this.imgOptions.url+"' width='"+this.imgOptions.width+"' height='"+this.imgOptions.height+"' style='border:none; ' alt='"+this.imgOptions.alt+"' /></a></div>";
document.write(vHtmlString);
this.id=$(this.id);
this.intervalId=setInterval(this.scroll.bind(this),this.delay);
this.id.onmouseover=this.stop.bind(this);
this.id.onmouseout=this.start.bind(this);
}、
スクロール:関数(){
var L=T=0;
var B=document.documentElement.clientHeight-this.id.offsetHeight;
var R=document.documentElement.clientWidth-this.id.offsetWidth;
this.id.style.left=this.adPosition.left+document.documentElement.scrollLeft+"px";
this.id.style.top=this.adPosition.top+document.documentElement.scrollTop+"px";
this.adPosition.left =this.adPosition.left + this.step*(this.herizonFlag?1:-1);
if (this.adPosition.left < L) { this.herizonFlag = true; this.adPosition.left = L;}
if (this.adPosition.left > R){ this.herizonFlag = false; this.adPosition.left = R;}
this.adPosition.top =this.adPosition.top + this.step*(this.verticleFlag?1:-1);
if(this.adPosition.top <= T){ this.verticleFlag=true; }
if(this.adPosition.top >= B){ this.verticleFlag=false;
}、
停止:関数(){
clearInterval(this.intervalId);
}、
開始:関数(){
this.intervalId=setInterval(this.scroll.bind(this),this.delay);
}
}