用JS实现一个旋转木马的代码是什么
Admin 2022-11-15 群英技术资讯 708 次浏览
这篇主要是介绍“用JS实现一个旋转木马的代码是什么”的内容了,下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家解决用JS实现一个旋转木马的代码是什么的问题,下面我们一起来了解看看吧。具体内容如下
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的video播放器的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要为大家详细介绍了JavaScript仿京东放大镜效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
Vue.Draggable实现交换位置,供大家参考,具体内容如下前言最近的一个项目接触了到了Vue.Draggable这个组件。不过我们的需求和Vue.Draggable这个组件所支持的有些出入。这个拖拽组件属于插入的模式。一但拖拽的是相间的元素(中间隔着几个元素),那么拖拽元素就会占据被拖拽元素的位置,而后续元素位置
本文实例为大家分享了JavaScript实现简单音乐播放器的具体代码,供大家参考,具体内容如下主要功能:快进、快退、暂停、上下一首、禁音、鼠标控制音量、自动下一首、显示歌名htmlhead @*不提供音频*@ meta name=viewport content=width=device-width /
本文给大家分享的是window下自带name的属性的内容,一些朋友可能对于window的name属性的作用和使用等等,不是很了解,对此这本文就简单的介绍一下,接下来我们一起了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008