JS DOM实现鼠标滑动图片效果


Posted in Javascript onSeptember 17, 2020

经常,我们在浏览各种网页的时候,都会有各种动画效果展示,像下图所示的是很多网上商城常用的货品展示方式,同类的货品并排展现在窗口上,用户如果看中了哪一款商品想要查看详情的话,只要将鼠标放上该商品的区域,原本折叠起来的商品便会自动展开,详情便会展现在用户面前,而这一动画,就是利用了DOM+JS结合来实现的,今天的小练习就是要实现这个效果。

JS DOM实现鼠标滑动图片效果

首先,先将页面基本的框架用html实现,将四张图封装在了一个名为“container”的div块中

<!doctype html>
<meta charset="UTF-8">
<html>
 <head>
 <title>
 鼠标滑过页面自动变大
 </title>
 <link rel="stylesheet" href="styles/reset.css" />
 <link rel="stylesheet" href="styles/slidingdoors.css" />
 <script src="slidlingdoors.js"></script>
 </head>
 <body>
 <div id="container">
 <img src="./images/door1.png"/>
 <img src="./images/door2.png"/>
 <img src="./images/door3.png"/>
 <img src="./images/door4.png"/>
 </div>
 </body>
</html>

接着,我将大体的样式用了两个样式表修饰如下:

依次为

slidingdoors.css和reset.css:
#container {
 height: 477px;
 margin: 0 auto;
 border-right: 1px solid #ccc;
 border-bottom: 1px solid #ccc;
 overflow: hidden;
 position: relative;
}

#container img {
 position: absolute;
 display: block;
 left: 0;
 border-left: 1px solid #ccc;
}
/**
 * Eric Meyer's Reset CSS v2.0 (http://meyerweb.com/eric/tools/css/reset/)
 * http://cssreset.com
 */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
 margin: 0;
 padding: 0;
 border: 0;
 font-size: 100%;
 font: inherit;
 vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
 display: block;
}
body {
 line-height: 1;
}
ol, ul {
 list-style: none;
}
blockquote, q {
 quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
 content: '';
 content: none;
}
table {
 border-collapse: collapse;
 border-spacing: 0;
}

接下来,就要实现滑动效果了,js代码如下:

window.onload=function(){
 var box=document.getElementById("container");
 var imgs=box.getElementsByTagName("img");
 var imgwidth=imgs[0].offsetWidth;
 var exposewidth=160;
 var boxwidth=imgwidth+exposewidth*(imgs.length-1);
 box.style.width=boxwidth+'px';
 function setImgPos(){
 for(var i=1;i<imgs.length;i++)
 {
 imgs[i].style.left=imgwidth+exposewidth*(i-1)+'px';
 }
 }
 setImgPos();
 var translate=imgwidth-exposewidth;
 for(var i=0;i<imgs.length;i++)
 {
 (function(i){
 imgs[i].onmouseover=function(){
 setImgPos();
 for(var j=1;j<=i;j++)
 {
  imgs[j].style.left=parseInt(imgs[j].style.left,10)-translate+'px';
 }
 };
 })(i);
 }
};

弄好后的效果图如下:

JS DOM实现鼠标滑动图片效果

遇到的问题:

1.图片复位函数中i、j变量傻傻分不清;

2.做出来的效果一张图片复位后把其余未复位图片都挡住了,主要是复位函数出了小问题。

经验:js函数变量复杂,逻辑严谨,写代码时一定要谨慎小心

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
javascript下IE与FF兼容函数收集
Sep 17 Javascript
在jQuery1.5中使用deferred对象 着放大镜看Promise
Mar 12 Javascript
自己做的模拟模态对话框实现代码
May 23 Javascript
EditPlus注册码生成器(js代码实现)
Mar 25 Javascript
js单向链表的具体实现实例
Jun 21 Javascript
fmt:formatDate的输出格式详解
Jan 09 Javascript
SuperSlide2实现图片滚动特效
Jun 20 Javascript
three.js实现围绕某物体旋转
Jan 25 Javascript
Angular.JS通过指令操作DOM的方法
May 10 Javascript
详解用webpack2搭建angular2的项目
Jun 22 Javascript
JavaScript对象拷贝与赋值操作实例分析
Dec 10 Javascript
sortable+element 实现表格行拖拽的方法示例
Jun 07 Javascript
实践中学习AngularJS表单
Mar 21 #Javascript
javascript单页面手势滑屏切换原理详解
Mar 21 #Javascript
javascript实现dom元素可拖动
Mar 21 #Javascript
AngularJS 中的指令实践开发指南(一)
Mar 20 #Javascript
浅析AngularJS中的指令
Mar 20 #Javascript
简述Matlab中size()函数的用法
Mar 20 #Javascript
详解Matlab中 sort 函数用法
Mar 20 #Javascript
You might like
星际争霸中的热键
2020/03/04 星际争霸
php intval的测试代码发现问题
2008/07/27 PHP
遍历指定目录,并存储目录内所有文件属性信息的php代码
2016/10/28 PHP
PHP上传图片到数据库并显示的实例代码
2019/12/20 PHP
HR vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
基于MooTools的很有创意的滚动条时钟动画
2010/11/14 Javascript
autoIMG 基于jquery的图片自适应插件代码
2011/03/12 Javascript
扩展jquery实现客户端表格的分页、排序功能代码
2011/03/16 Javascript
jsp js鼠标移动到指定区域显示选项卡离开时隐藏示例
2013/06/14 Javascript
JS控制阿拉伯数字转为中文大写示例代码
2013/09/04 Javascript
完美兼容IE,chrome,ff的设为首页、加入收藏及保存到桌面js代码
2014/12/17 Javascript
jQuery中outerWidth()方法用法实例
2015/01/19 Javascript
Jquery表单验证失败后不提交的解决方法
2016/10/18 Javascript
js实现上传图片预览方法
2016/10/25 Javascript
浅谈js函数的多种定义方法与区别
2016/11/29 Javascript
node.js+captchapng+jsonwebtoken实现登录验证示例
2017/08/17 Javascript
浏览器事件循环与vue nextTicket的实现
2019/04/16 Javascript
[14:20]刀塔大凶女神互压各路奇葩屌丝
2014/05/16 DOTA
利用Fn.py库在Python中进行函数式编程
2015/04/22 Python
Windows下实现Python2和Python3两个版共存的方法
2015/06/12 Python
python实现壁纸批量下载代码实例
2018/01/25 Python
Python中 map()函数的用法详解
2018/07/10 Python
Python测试网络连通性示例【基于ping】
2018/08/03 Python
python实现贪吃蛇小游戏
2020/03/21 Python
浅谈python的深浅拷贝以及fromkeys的用法
2019/03/08 Python
python 字典 setdefault()和get()方法比较详解
2019/08/07 Python
Python函数参数类型及排序原理总结
2019/12/19 Python
Django模型中字段属性choice使用说明
2020/03/30 Python
python下载的库包存放路径
2020/07/27 Python
html5 Canvas绘制线条 closePath()实例代码
2012/05/10 HTML / CSS
德国家具、照明、家居用品网上商店:Wayfair.de
2020/02/13 全球购物
高中军训感言400字
2014/02/24 职场文书
学习两会精神心得范文
2014/03/17 职场文书
工作感想范文
2015/08/07 职场文书
python opencv通过按键采集图片源码
2021/05/20 Python
MySQL普通表如何转换成分区表
2022/05/30 MySQL