js实现图片推拉门效果代码实例
2019-05-18 18:01
2106 查看
初学者。
推拉门是网页中常见的一种形式,通过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实现图片推拉门效果代码实例详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- JS小功能(setInterval实现图片效果显示时间)实例代码
- 使用JS实现图片展示瀑布流效果的实例代码
- JS小功能(offsetLeft实现图片滚动效果)实例代码
- JS小功能(offsetLeft实现图片滚动效果)实例代码
- JS小功能(setInterval实现图片效果显示时间)实例代码
- JS返回上一页实例代码通过图片和按钮分别实现
- JS实现图片翻书效果示例代码
- 原生js图片轮播效果实现代码
- JS实现图片翻书效果示例代码
- js实现点击左右按钮轮播图片效果实例
- 使用JS实现图片展示瀑布流效果(简单实例)
- JS实现分页浏览横向图片(类轮播)实例代码
- JS+DIV实现鼠标划过切换层效果的实例代码
- js实现单行文本向上滚动效果实例代码
- js实现图片轮番效果,原生代码
- js图片轮播效果实现代码
- JS实现的仿QQ空间图片弹出效果代码
- JS实现简易的图片拖拽排序实例代码
- JS 非图片动态loading效果实现代码
- 最简单的js图片切换效果实现代码