注册通行证 用户名 密码
  • 文章投稿
  • 博客
  • 论坛
  • 设为首页
  • 加入收藏
jztop.com网络技术
  • 首页
  • | iT新闻
  • | 操作系统
  • | 组网建网
  • | 网络安全
  • | 程序开发
  • | 办公一族
  • | 工具软件
  • | 网页制作
  • | 多媒体制作
  • | 网吧技术
  • | 服务器
  • | 专题教程
Vista | 软件评测 | 系统备份 | 优化 | 进程 | 聊天 | 病毒 | Linux | 黑客 | 防火墙 | 数据库 | Web开发 | Java | Word | 游戏 | 32位开发 | 移动开发
当前位置:首页 > 网页制作 > JavaScript技术 内容正文:飘浮广告的显示脚本类(VBS,JS双版)

飘浮广告的显示脚本类(VBS,JS双版)

发布时间:2006-07-20 07:55:11 来源:天极网 网友评论 0 条
在写一个项目时要用到广告模块,为了不想用ASP生成脚本代码时较麻烦,于是产生了写脚本类的念头,即是用一个类模块的脚本代码去控制所有在同一页面显示的漂浮广告。但在写的过程中发现JS脚本竟然在setTimeout里不能使用类的方法。奇怪,是不是我弄错了还是JS脚本就不能这样??但VBS脚本就可以!我晕……
不说了,贴代码:

[VBS脚本代码]
以下是代码片段:
以下是引用片段:
'/****************漂浮广告显示类**************************************************** 
'/* 作者:死在水中的鱼 
'/* 脚本语言:VBS 
'/* 用法: 
'/* Set Adver1=New AdverClass 
'/* Adver1.ObjName="Adver1" '设置当前的对象名 [本身对象变量名] 
'/* Adver1.ImgType=1 '图片的类型 0=普通图片 1=Flash动画 
'/* Adver1.ImageWidth=299 '图片的宽度 
'/* Adver1.ImageHeight=87 '图片的高度 
'/* ####以下方法显示广告图片(Flash) 对象.PrintHtml "图片地址","链接地址","提示信息" 
'/* Adver1.PrintHtml "http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/' target="_blank" >http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/","这是什么" 
'/*********************************************************************************** 
Class AdverClass 
Public DivID 
Public ObjName 
Private ObjDiv 
Public Delay '改变数 
Public ImgType 
Private iStep 
Private iTop,iLeft,Width,Height 
Private TopFlag,LeftFlag 
'广告图片的大小 
Public ImageWidth,ImageHeight 
Private Sub Class_Initialize 
Randomize 
DivID=Int(Rnd(Time)*9999+1) 
Delay=80 
Height=document.body.clientHeight 
Width=document.body.clientWidth 
iTop=0 
iLeft=0 
TopFlag=False:LeftFlag=False 
iStep=3 
ImgType=0 '0 是图片 1 是FLASH文件 
ImageWidth=0 
ImageHeight=0 
End Sub 
Private Sub Class_Terminate 
End Sub 
Public Sub ScrollImg() 
Dim offHeight,offWidth,iRnd 
offWidth=ObjDiv.offsetWidth 
offHeight=ObjDiv.offsetHeight 
ObjDiv.style.left = iLeft + document.body.scrollLeft 
ObjDiv.style.top = iTop + document.body.scrollTop 
iRnd=Int(Rnd(Time)*99+1) 
If iRnd>97 Then TopFlag=Not TopFlag 
iRnd=Int(Rnd(Time)*9+1) 
If iRnd>98 Then LeftFlag=Not LeftFlag 
If TopFlag Then 
iTop=iTop+iStep*Rnd(Time) 
Else 
iTop=iTop-iStep*Rnd(Time) 
End If 
If LeftFlag Then 
iLeft=iLeft+iStep*Rnd(Time) 
Else 
iLeft=iLeft-iStep*Rnd(Time) 
End If 
If iTop<0 Then 
iTop=0 
TopFlag=True 
ElseIf iTop>Height-offHeight Then 
iTop=Height-offHeight 
TopFlag=False 
End If 
If iLeft<0 Then 
iLeft=0 
LeftFlag=True 
ElseIf iLeft>Width-offWidth Then 
iLeft=Width-offWidth 
LeftFlag=False 
End If 
End Sub 
Private Sub Start() 
setInterval ObjName&".ScrollImg()", Delay 
End Sub 
Public Sub PrintHtml(ByVal ImgSrc,ByVal adHref,ByVal adTitle) 
If ImgType=0 Then 
Call PrintImageHtml(ImgSrc,adHref,adTitle) 
Else 
Call PrintFlashHtml(ImgSrc,adHref,adTitle) 
End If 
Execute "Set ObjDiv=document.all.img"&DivID 
iLeft=Int(Rnd(Time)*(Width-100)+1) 
iTop=Int(Rnd(Time)*(Height-100)+1) 
ObjDiv.style.top=iTop 
ObjDiv.style.left=iLeft 
Call Start() 
End Sub 
Private Sub PrintImageHtml(ByVal ImgSrc,ByVal adHref,ByVal adTitle) 
If ImageWidth=0 Or Not IsNumeric(ImageWidth) Then 
ImageWidth="" 
Else 
ImageWidth=" width='"&ImageWidth&"'" 
End If 
If ImageHeight=0 Or Not IsNumeric(ImageHeight) Then 
ImageHeight="" 
Else 
ImageHeight=" height='"&ImageHeight&"'" 
End If 
document.write "<div id=""img"&DivID&""" style=""position:absolute;"">" 
document.write "<a href="""&adHref&""" target=""_blank"" title='"&adTitle&"'>" 
document.write "<img src="""&ImgSrc&""" alt="""&adTitle&""" border=""0"""&ImageWidth&ImageHeight&"></a></div>" 
End Sub 
Private Sub PrintFlashHtml(ByVal ImgSrc,ByVal adHref,ByVal adTitle) 
If ImageWidth=0 Or Not IsNumeric(ImageWidth) Then 
ImageWidth=80 
End If 
ImageWidth=" width='"&ImageWidth&"'" 
If ImageHeight=0 Or Not IsNumeric(ImageHeight) Then 
ImageHeight=80 
End If 
ImageHeight=" height='"&ImageHeight&"'" 
document.write "<div id=""img"&DivID&""" style=""position:absolute;"">" 
document.write "<a href="""&adHref&""" target=""_blank"" title='"&adTitle&"'>" 
document.write "<object codebase='http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,29,0'"&ImageWidth&ImageHeight&" align='middle'>" 
document.write "<param name='movie' value='"&ImgSrc&"'>" 
document.write "<param name='quality' value='high'>" 
document.write "<embed src='"&ImgSrc&"'"&ImageWidth&ImageHeight&" quality='high' pluginspage='http://www.macromedia.com/go/getflashplayer' type='application/x-shockwave-flash'></embed></object>" 
document.write "</a></div>" 
End Sub 
End Class
 


[JS脚本]
以下是代码片段:
以下是引用片段:
file://*****************漂浮广告显示类**************************************************** 
file://* 作者:死在水中的鱼 
file://* 脚本语言:Javascript 
file://* 用法: 
file://* var adver=new adverClass 
file://* adver.setObjName("adver"); file://这句不能setTime所以没有用 
file://* adver.setDivID(1); file://这句可以不用 
file://* adver.setImageType(1); file://设为0时或不写这句时则是普通图片,1则为Flash动画文件 
file://* adver.setImagePX(299,87); file://设置图片的宽度与高度 
file://* adver.showAdver("http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/' target="_blank" >http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/","这是什么"); 
file://* var adver1=new adverClass(); 
file://* adver1.showAdver("img.gif","http://www.chinese.bj.cn/","这是什么"); 
file://* setTimer(); 
file://* file://因为类里不能写setTime所以只好拿出来写-_-##(VBS脚本竟然可以。我倒) 
file://* function setTimer(){ 
file://* adver.floatScroll(); 
file://* adver1.floatScroll(); 
file://* setTimeout("setTimer()",80); 
file://* } 
file://*********************************************************************************** 
function adverClass(){ 
var objName=""; 
var imageType=0; 
var imageWidth=imageHeight=0; 
var iTop=iLeft=0; 
var topFlag=leftFlag=false; 
var divID=0,objDiv=null; 
var offWidth=offHeight=0; 
var width=document.body.clientWidth; 
var height=document.body.clientHeight; 
var delay=30; file://时间的延迟值 
var topStep=2,leftStep=3; file://一步跨多少 
var inter; 
file://此处是当外部不设置divID的值能够确保层的ID是唯一 
divID=Math.round(Math.random()*100000) 
file://广告的类型 0=普通图片 1=Flash广告图片 
this.setImageType=function(sType){ 
if(sType!=1&&sType!=0){sType=0;} 
imageType=sType; 
} 
file://外部调用的变量名 
this.setObjName=function(sName){objName=sName;} 
file://广告图片的高度与宽度 
this.setImagePX=function(iWidth,iHeight){ 
if(!isNaN(iWidth)){ 
imageWidth=iWidth; 
}else{ 
imageWidth=0; 
} 
if(!isNaN(iHeight)){ 
imageHeight=iHeight; 
}else{ 
imageHeight=0; 
} 
} 
file://设置广告所在层的ID值 
this.setDivID=function(iDiv){divID=iDiv;} 

file://主函数,显示广告代码 
this.showAdver=function(adImgSrc,adHref,adTitle){ 
if(imageType==0){ 
showImageHtml(adImgSrc,adHref,adTitle); 
}else{ 
showFlashHtml(adImgSrc,adHref,adTitle); 
} 
eval("objDiv=document.all.img"+divID+";"); 
file://取得图片的宽度 
offWidth=objDiv.offsetWidth; 
offHeight=objDiv.offsetHeight; 
file://随机显示广告的开始位置 
iLeft=Math.round(Math.random()*(width-offWidth)); 
iTop=Math.round(Math.random()*(height-offHeight)); 
objDiv.style.pixelLeft=iLeft; 
objDiv.style.pixelTop=iTop; 
file://定时开始 
file://startTimer(); 
} 
file://主函数,漂浮游动显示广告 
this.floatScroll=function(){ 
var iRnd; 
iRnd=Math.round(Math.random()*100); file://此值是为了能使多图显示时产生不同的轨迹 
if(objDiv==null)return; 
objDiv.style.pixelLeft = iLeft + document.body.scrollLeft; 
objDiv.style.pixelTop = iTop + document.body.scrollTop; 
if(iRnd>98){leftFlag=!leftFlag;} 
iRnd=Math.round(Math.random()*100); 
if(iRnd>99){topFlag=!topFlag;} 
if(leftFlag){ 
iLeft=iLeft+leftStep*Math.random(); 
}else{ 
iLeft=iLeft-leftStep*Math.random(); 
} 
if(topFlag){ 
iTop=iTop+topStep*Math.random(); 
}else{ 
iTop=iTop-topStep*Math.random(); 
} 
if(iLeft<0){ 
iLeft=0; 
leftFlag=true; 
} 
else if(iLeft>width-offWidth){ 
iLeft=width-offWidth; 
leftFlag=false; 
} 
if(iTop<0){ 
iTop=0; 
topFlag=true; 
} 
else if(iTop>height-offHeight){ 
iTop=height-offHeight; 
topFlag=false; 
} 
} 
file://定时移动广告的图片 
function startTimer(){ 
if(objName=="")return; 
file://alert(objName+".floatScroll();"); 
file://inter=setInterval(objName+".floatScroll()",delay); 
} 
file://显示图片的HTML代码 
function showImageHtml(adImgSrc,adHref,adTitle){ 
var sWidth,sHeight; 
if(imageWidth<5){ 
sWidth=""; 
}else{ 
sWidth=" width='"+imageWidth+"'"; 
} 
if(imageHeight<5){ 
sHeight=""; 
}else{ 
sHeight=" height='"+imageHeight+"'"; 
} 
document.write("<div id='img"+divID+"' style='position:absolute;'>"); 
document.write("<a href='"+adHref+"' target='_blank' title='"+adTitle+"'>"); 
document.write("<img src='"+adImgSrc+"' border='0'"+sWidth+sHeight+">"); 
document.write("</a></div>"); 
} 
file://显示Flash文件的HTML代码 
function showFlashHtml(adImgSrc,adHref,adTitle){ 
var sWidth,sHeight; 
if(imageWidth<5){ 
sWidth=" width='80'"; 
}else{ 
sWidth=" width='"+imageWidth+"'"; 
} 
if(imageHeight<5){ 
sHeight=" height='80'"; 
}else{ 
sHeight=" height='"+imageHeight+"'"; 
} 
document.write("<div id='img"+divID+"' style='position:absolute;'>"); 
document.write("<a href='"+adHref+"' target='_blank' title='"+adTitle+"'>"); 
document.write("<object codebase='http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,29,0'"+sWidth+sHeight+" align='middle'>"); 
document.write("<param name='movie' value='"+adImgSrc+"'>"); 
document.write("<param name='quality' value='high'>"); 
document.write("<embed src='"+adImgSrc+"'"+sWidth+sHeight+" quality='high' pluginspage='http://www.macromedia.com/go/getflashplayer' type='application/x-shockwave-flash'></embed></object>"); 
document.write("</a></div>"); 
} 
} 

示例代码(包括两种脚本的使用):
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> 漂浮广告显示脚本类演示 </TITLE>
</HEAD>

<BODY>
<!--VBS脚本版的广告显示类示例程序-->
<script LANGUAGE="vbscript" src="Advervbs.vbs"></script>
<script LANGUAGE="vbscript">
Dim Adver,Adver1
Set Adver=New AdverClass
Adver.ObjName="Adver"
Adver.DivID=20
Adver.PrintHtml "img.gif","http://www.chinese.bj.cn/","这是什么"
Set Adver1=New AdverClass
Adver1.ObjName="Adver1"
Adver1.ImgType=1
Adver1.ImageWidth=299
Adver1.ImageHeight=87
Adver1.PrintHtml "http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/' target="_blank" >http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/","这是什么"
</script>
<!--JS脚本版的广告显示类示例程序-->
<script LANGUAGE="Javascript" src="AdverClass.js"></script>
<script LANGUAGE="Javascript">
var adver=new adverClass();
adver.setObjName("adver");
adver.setDivID(1);
adver.setImageType(1);
adver.setImagePX(299,87);
adver.showAdver("http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/' target="_blank" >http://edu.qq.com/flash/moto-button.swf","http://www.chinese.bj.cn/","这是什么");
var adver1=new adverClass();
adver1.showAdver("img.gif","http://www.chinese.bj.cn/","这是什么");
setTimer();
function setTimer(){
adver.floatScroll();
adver1.floatScroll();
setTimeout("setTimer()",80);
}
</script>
</BODY>
</HTML>

  


  
相关文章
    无相关信息
【评论】【收藏本文】【打印】【关闭】
上一篇文章:脚本实例:用 JavaScript 来操作字符串
下一篇文章:应用实例:用Javascript实现定时任务
讨论区
查看
已有 0 位对此新闻感兴趣的网友发表了看法
匿名发表
注册通行证 登陆
图文阅读推荐
推荐阅讯
  • 下拉菜单的简单制作
  • Javascript的一种模块模式
  • 限量版广告 1个IP一天只弹一次的AD代码
  • 特效:页面内容在设定时间后消失
  • 特效:一个可以用来做招牌字的特效
  • Javascript脚本实现静态网页加密
  • 链接中的JS 特效功能代码大放送
  • 使用AJAX的十大理由
  • JavaScript和Java Applet有什么区别?
  • 谈AS+JS的Flash网站无刷新定位技术
阅读排行
  • 1.网页特效:一段实用的图片滚动显示代码
  • 2.网页特效实例:用js获取单选按钮的数据
  • 3.Javascript特效:随机显示图片的源代码
  • 4.Javascript技术技巧大全
  • 5.IE和FireFox下javascript读写XML实现广告轮
  • 6.用 JavaScript 来操作字符串的函数
  • 7.添加到收藏夹的Javascript脚本-适合IE和Fir
  • 8.怎样判断浏览器是否支持javascript?
  • 9.JavaScript实现网页图片等比例缩放
  • 10.网页特效:随机显示广告的JS源代码
专题教程
  • 大话G游 专题:手机病毒揭密
  • ARP攻击防范与解决方案 路由故障处理手册
  • Picasa中文版_Picasa教程 专题:清除流氓软件
  • Firefox专题 seo搜索引擎优化专区
  • 重装Windows必知的事情 装机之必备软件大行动
病毒专杀栏
  • 杀毒软件反被病毒杀 连"救命"都不能喊
  • 金山ARP防火墙
  • 还原卡神话破灭“机器狗”病毒来势汹汹
  • cctv经济半小时:你的手机现在安全吗?
  • 新挂马方式开始流行 ARP挂马称雄局域网
  • 木马和病毒清除的通用解法
  • IP地址不再冲突 查找ARP攻击者元凶
  • 教你几招识别和防御Web网页木马
  • 分析:封杀BT只是暂时的止痛药
  • QQ爆危险漏洞,“QQ游戏邀请大盗”邀请你玩病
关于我们 | 诚聘英才 | 联系我们 | 版权声明 | 网站大事 | 网站地图 | 意见建议
CopyRight 2005-2007 Jztop.Com 版权所有 未经许可 请勿转载