本文实例讲述了javascript+html5实现仿flash滚动播放图片的方法。分享给大家供大家参考。具体如下:
html部分:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <script src="/UploadFiles/2021-04-02/move.js">css部分:
body{ margin: 0px; padding: 0px; } ul{ margin: 0px; padding: 0px; } li{ list-style: none; } .play{ width: 600px; height: 550px; left: 30px; top: 20px; position: relative; border: 2px solid black; } .big_pic{ width: 600px; height: 400px; position: relative; background: snow; overflow: hidden; } .big_pic li{ width: 600px; height: 400px; overflow:hidden; position: absolute; background: black; z-index: 0 } .big_pic li img{ width: 600px; height: 400px; position: absolute; } .mark_left{ width: 300px; height: 400px; background: orange; position: absolute; left: 0px; top: 0px; z-index: 3000; filter: alpha(opacity:0); opacity: 0; } .mark_right{ width: 300px; height: 400px; background: cornflowerblue; position: absolute; left: 300px; top: 0px; z-index: 3000; filter: alpha(opacity:0); opacity: 0; } .prev{ width: 60px; height: 60px; background: url(image/btn.gif) no-repeat; position: absolute; z-index: 3001; top: 170px; left: 10px; cursor: pointer; filter: alpha(opacity:0); opacity: 0; } .next{ width: 60px; height: 60px; background: url(image/btn.gif) no-repeat 0 -60px; position: absolute; z-index: 3001; top: 170px; right: 10px; cursor: pointer; filter: alpha(opacity:0); opacity: 0; } .small_pic{ width: 594px; height: 144px; position: relative;top: 0;left: 0; border: 3px solid paleturquoise;overflow: hidden; } .small_pic ul{ width: 594px; height: 144px; position: absolute; left: 0px;top: 0px; } .small_pic li img{ width: 194px; height: 140px; } .small_pic ul li{ border:2px solid paleturquoise; width: 194px; height: 140px; float: left; cursor: pointer; filter: alpha(opacity:60); opacity: 0.6; }JS部分:
window.onload=function(){ var oPlay=document.getElementById('playImages'); var uBig=getClass(oPlay,'big_pic')[0]; var uSmall=getClass(oPlay,'small_pic')[0]; var oPrev=getClass(oPlay,'prev')[0]; var oNext=getClass(oPlay,'next')[0]; var aLeft=getClass(oPlay,'mark_left')[0]; var aRight=getClass(oPlay,'mark_right')[0]; var oUlSmall=uSmall.getElementsByTagName('ul')[0]; var oSli=uSmall.getElementsByTagName('li'); var oBli=uBig.getElementsByTagName('li'); oUlSmall.style.width=oSli[0].offsetWidth*oSli.length+'px'; oPrev.onmouseover=aLeft.onmouseover=function(){ move(oPrev,100,'opacity'); }; oPrev.onmouseout=aLeft.onmouseout=function(){ move(oPrev,0,'opacity'); }; oNext.onmouseover=aRight.onmouseover=function(){ move(oNext,100,'opacity'); }; oNext.onmouseout=aRight.onmouseout=function(){ move(oNext,0,'opacity'); }; var index=0; var newZIndex=2; for (var i=0;i<oSli.length;i++){ oSli[i].num=i; oSli[i].onclick=function(){ if(this.num==index) { return; } else{ index=this.num; tab(); } }; oSli[i].onmouseover=function(){ move(this,100,'opacity'); }; oSli[i].onmouseout=function(){ if(this.num!=index){ move(this,60,'opacity'); } }; } oPrev.onclick=function(){ index--; if(index==-1){ index=oSli.length-1; } tab(); }; oNext.onclick=function(){ index++; if(index==oBli.length){ index=0; } tab(); }; function tab() { oBli[index].style.height = 0; oBli[index].style.zIndex = newZIndex++; move(oBli[index], 400, 'height'); for (var i = 0; i < oSli.length; i++) { move(oSli[i], 60, 'opacity'); } move(oSli[index], 100, 'opacity'); if (index == 0) { move(oUlSmall, 0, 'left'); } else if (index == oSli.length - 1) { move(oUlSmall, -(index - 2) * oSli[0].offsetWidth, 'left'); } else { move(oUlSmall, -(index - 1) * oSli[0].offsetWidth, 'left'); } }; var timer=setInterval(oNext.onclick,3000);; oPlay.onmouseover=function(){ clearInterval(timer); }; oPlay.onmouseout=function(){ timer=setInterval(oNext.onclick,3000); }; }; function getStyle(obj,name){ if(obj.currentStyle){ return obj.currentStyle[name]; }else{ return getComputedStyle(obj,false)[name]; } }; function move(obj,iTarget,name){ clearInterval(obj.timer); obj.timer=setInterval(function(){ var cur=0; if(name=='opacity'){ cur=Math.round(parseFloat(getStyle(obj,name))*100); }else{ cur=parseInt(getStyle(obj,name)); } var speed=(iTarget-cur)/30; speed=speed>0"px"; } } },30); }; function getClass(oParent,name){ var oArray=[]; var oBj=oParent.getElementsByTagName('*'); for(var i=0;i<oBj.length;i++){ if(oBj[i].className==name){ oArray.push(oBj[i]); } } return oArray; }希望本文所述对大家的javascript程序设计有所帮助。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月19日
2024年11月19日
- 陈奕迅2023《CHIN UP》EAS MUSIC[WAV+CUE][1.2G]
- 黄心懋《曾经有个女孩》滚石首版[WAV+CUE]
- 群星《车宴(紫银合金AQCD)》[原抓WAV+CUE]
- 小骆驼《草原狼》[正版CD抓轨WAV+CUE]
- 群星.2011-剧集金曲精选2CD【永恒】【WAV+CUE】
- 林忆莲.1996-夜太黑【滚石】【WAV+CUE】
- 方皓玟.2009-UNLOCKME【东亚】【WAV+CUE】
- 群星《2024好听新歌22》十倍音质 U盘音乐[WAV分轨]
- 林宥嘉《神秘嘉宾》引进版[WAV分轨][1G]
- 2024罗志祥《舞狀元》[FLAC/MP3][1G]
- 张美玲侯俊辉1999-福建情歌对唱[南方][WAV+CUE]
- 江希文.1994-伝说少女(饿狼伝说动画原声大碟)【嘉音】【WAV+CUE】
- 黄思婷2020-风中泪[豪记][WAV+CUE]
- 刘韵.1998-DENON.MASTERSONIC系列【EMI百代】【WAV+CUE】
- 群星.2024-你的谎言也动听影视原声带【韶愔音乐】【FLAC分轨】