温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JavaScript中怎么实现一个滑动门效果

发布时间:2021-07-06 16:51:07 来源:亿速云 阅读:164 作者:Leah 栏目:开发技术

JavaScript中怎么实现一个滑动门效果,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

一、什么是滑动门

首先你要了解什么是滑动门。生活中我们经常看到一些网站或是商城有一些滑动门的效果

那么怎么实现一个简单的滑动门的网页特效呢?下面简单分享一下方法,

二、实现滑动门所需技术

1、简单的HTML基础知识2、简单的CSS基础样式3、基本的javascript知识

三、如何实现滑动门(重点)

准备好一段HTML代码

<p id="container">  <img src="images/20190503222903.png"/><!--图片可以自己修改-->  <img src="images/20190503222943.png"/>  <img src="images/20190503223003.png"/>  <img src="images/20190503223514.png"/></p>

给当前HTML结构添加样式

*{  margin: 0;  padding: 0;  background-color: #ccc;}p{  text-align: center;}#container{  width: 1130px;  height: 350px;  margin: 0 auto;  border-right:1px solid #FF0000;  border-bottom:1px solid #FF0000;  overflow: hidden;  position: relative;}#container img{  width:500px;  height:350px;  display: block;  position: absolute;  border-bottm:1px solid #FF0000;}

最后使用js代码实现效果

//加载dom树window.onload = function(){//定义盒子var box=document.getElementById('container');//定义图片var imgs=box.getElementsByTagName('img');//图片宽度var imgWidth = imgs[0].offsetWidth;//隐藏宽度var exposeWidth = 210;//盒子宽度var boxWidth = imgWidth + (imgs.length -1) * exposeWidth;box.style.width='px';//设置每道门的初始位置function SetImgsPos(){for(var i = 1;i<imgs.length;i++){      imgs[i].style.left = imgWidth + exposeWidth*(i -1)+ 'px';      }    }    SetImgsPos();     //计算每道门应该移动的距离    var translate = imgWidth - exposeWidth;    //为每道门绑定事件    for(var i=0;i<imgs.length;i++){      //使用立即调用的函数表达式,为了获得不同的i值      (function(i){        imgs[i].onmouseover = function(){          SetImgsPos();          //打开门          for(var j=1;j<=i;j++){            imgs[j].style.left = parseInt(imgs[j].style.left,10) - translate + 'px';          }        }      })(i);    }  }

关于JavaScript中怎么实现一个滑动门效果问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI