用JS实现一个旋转木马的代码是什么
Admin 2022-11-15 群英技术资讯 284 次浏览
具体内容如下
html部分
<div class="wrap" id="wrap"> <div class="slide" id="slide"> <ul> <li><a href=""><img src="images/slidepic1.jpg" alt=""></a></li> <li><a href=""><img src="images/slidepic2.jpg" alt=""></a></li> <li><a href=""><img src="images/slidepic3.jpg" alt=""></a></li> <li><a href=""><img src="images/slidepic4.jpg" alt=""></a></li> <li><a href=""><img src="images/slidepic5.jpg" alt=""></a></li> </ul> <div class="arrow" id="arrow"> <a href="javascript:" id="next"></a> <a href="javascript:" id="prev"></a> </div> </div> </div>
css部分
@charset "UTF-8"; /*初始化 reset*/ blockquote,body,button,dd,dl,dt,fieldset,form,h1,h2,h3,h4,h5,h6,hr,input,legend,li,ol,p,pre,td,textarea,th,ul{margin:0;padding:0} body,button,input,select,textarea{font:12px/1.5 "Microsoft YaHei", "微软雅黑", SimSun, "宋体", sans-serif;color: #666;} ol,ul{list-style:none} a{text-decoration:none} fieldset,img{border:0;vertical-align:top;} a,input,button,select,textarea{outline:none;} a,button{cursor:pointer;} .wrap { margin: 100px auto; width: 1200px; } .slide { height: 500px; position: relative; } .slide li { position: absolute; left: 200px; top: 0; } .slide li img { width: 100%; } .arrow { opacity: 0; } #next,#prev { width: 76px; height: 112px; position: absolute; top: 50%; margin-top: -56px; background: url("../images/prev.png") no-repeat; z-index: 99; } #next { background-image: url("../images/next.png"); right: 0; }
js部分
<script src="common.js"></script> <script> var config = [ { width: 400, opacity: 0.2, height: 250, left: 50, top: 20, zIndex: 2 },//0 { width: 600, opacity: 0.7, height: 350, left: 0, top: 70, zIndex: 3 },//1 { width: 800, opacity: 1, height: 500, left: 200, top: 100, zIndex: 4 },//2 { width: 600, opacity: 0.7, height: 350, left: 600, top: 70, zIndex: 3 },//3 { width: 400, opacity: 0.2, height: 250, left: 750, top: 20, zIndex: 2 }//4 ]; //页面加载事件 window.onload = function () { var flag=true;//默认所有的动画都结束了 //获取li标签 var list = my$("slide").getElementsByTagName("li"); //散开图片 function assign() { for (var i = 0; i < list.length; i++) { animate(list[i], config[i],function () { flag=true;//回调函数,当动画加载完后,flag变为true }); } } assign(); //点击右边焦点 my$("next").onclick = function () { if (flag){ flag=false; config.push(config.shift());//把数组中的第一个元素作为返回值并追加加到这个数组的最后面 assign(); } }; //点击左边焦点 my$("prev").onclick = function () { if (flag){ flag=false; config.unshift(config.pop());//把数组的最后一个元素作为返回值并追加到这个数组的最前面 assign(); } }; //鼠标进入逐渐的显示左右焦点 my$("slide").onmouseover=function () { animate(my$("arrow"),{"opacity":1}); }; //鼠标离开隐藏 my$("slide").onmouseout = function () { animate(my$("arrow"),{"opacity":0}); }; }; </script>
common.js部分
//根据id获取元素对象 function my$(id) { return document.getElementById(id); } /* * element---任意的元素 * attr---属性 * */ function getAttrValue(element,attr) { return element.currentStyle?element.currentStyle[attr] : window.getComputedStyle(element,null)[attr]||0; } //动画函数 function animate(element,json,fn) { clearInterval(element.timeId); element.timeId=setInterval(function () { var flag=true;//假设都达到了目标 for(var attr in json){ if(attr=="opacity"){//判断属性是不是opacity var current= getAttrValue(element,attr)*100; //每次移动多少步 var target=json[attr]*100;//直接赋值给一个变量,后面的代码都不用改 var step=(target-current)/10;//(目标-当前)/10 step=step>0?Math.ceil(step):Math.floor(step); current=current+step; element.style[attr]=current/100; }else if(attr=="zIndex"){//判断属性是不是zIndex element.style[attr]=json[attr]; }else{//普通的属性 //获取当前的位置----getAttrValue(element,attr)获取的是字符串类型 var current= parseInt(getAttrValue(element,attr))||0; //每次移动多少步 var target=json[attr];//直接赋值给一个变量,后面的代码都不用改 var step=(target-current)/10;//(目标-当前)/10 step=step>0?Math.ceil(step):Math.floor(step); current=current+step; element.style[attr]=current+"px"; } if(current!=target){ flag=false;//如果没到目标结果就为false } } if(flag){//结果为true clearInterval(element.timeId); if(fn){//如果用户传入了回调的函数 fn(); //就直接的调用, } } console.log("target:"+target+"current:"+current+"step:"+step); },10); }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了 vue中v-for 循环对象中的属性,文章围绕v-for 循环对象的相关资料展开详细内容,需要的朋友可以参考一下,希望对大家有所帮助
Javascript修改元素属性怎样做?想要修改元素属性,我们可以使用元素对象.attribute = new value和setAttribute()函数这两种方法,具体怎样使用呢?文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
目录基本用法监听object使用deep参数重新赋值通过路径监听内部数据初始化变量触发监听回调总结Vue中可以使用监听器监听属性的变化,并根据属性变化作出响应。但一旦涉及到复杂数据的监听(如Object,但数组一般不需要,因为Vue针对数组做了特殊处理)时就比较复杂了,本文解释了使用watch监听属性变化的方法,包括复
这篇文章主要为大家详细介绍了Vue实现大屏页面的屏幕自适应,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
今天给大家分享的是用JavaScrip实现阻止超链接跳转的内容,本文介绍了通过多种写法来实现这一功能的实例,感兴趣的朋友可以了解看看,接下来跟随小编一起学习一下吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008