您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
初学者。
推拉门是网页中常见的一种形式,通过JS实现比较简单。主要是通过getElement找到节点元素,然后对其进行相应的赋值即可。
新建一个index.html文件,并在同一个目录中添加三个文件夹,images(用来当作“门”的图片),styles(用来存放css文件),scripts(用来存放js文件)。然后在index.html中添加代码:
<!doctype html> <html> <head> <meta charset="utf-8"/> <title>sliding doors</title> <link rel="stylesheet" href="styles/doors.css" rel="external nofollow" /> <script src="scripts/doors.js"></script> </head> <body> <div id="container"> <img src="images/door1.jpg" alt="柯南" title="柯南"/> <img src="images/door2.jpg" alt="柯南" title="柯南"/> <img src="images/door3.jpg" alt="柯南" title="柯南"/> <img src="images/door4.jpg" alt="柯南" title="柯南"/> </div> </body> </html>
接着是styles目录下的doors.css:
#container{
height:600px;
border-right:1px solid #ccc;
border-bottom:1px solid #ccc;
margin:0 auto;
position:relative;
overflow:hidden;
}
#container img{
position:absolute;
border-left:1px solid #ccc;
display:block;
left:0;
}
然后是scripts目录下的doors.js:
window.onload = function()
{
var box = document.getElementById("container"); //获得容器对象
var imgs = box.getElementsByTagName("img"); //获得图片对象数组
imgWidth = imgs[0].offsetWidth; //图片宽度
var exposeWidth = 100; //每张图片露出的宽度
var boxWidth = imgWidth + exposeWidth * (imgs.length - 1);
box.style.width = boxWidth + "px";
//初始化图片位置
function reset()
{
for(var i = 1; i < imgs.length; i ++)
{
imgs[i].style.left = imgWidth + (i - 1) * exposeWidth + "px";
}
}
reset();
//开门时候每个图片应该左移的距离
var translate = imgWidth - exposeWidth;
//为每个图片添加事件
for(var i = 0; i < imgs.length; i ++)
{
//自动执行函数
(function(i){
imgs[i].onmouseover = function()
{
//重置图片位置
reset();
for(var j = 1; j <= i; j ++)
{
imgs[j].style.left = parseInt(imgs[j].style.left, 10) - translate + "px";
}
};
})(i);
}
};
这样即可实现推拉门效果。
效果如下,截图略微粗糙

以上所述是小编给大家介绍的js实现图片推拉门效果代码实例详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对亿速云网站的支持!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。