html中图片鼠标滑动的效果,JS DOM实现鼠标滑动图片效果

news/2024/11/24 22:52:25/

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

cb7ac7a99178d271035238619085329d.png

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

鼠标滑过页面自动变大

door1.png

door2.png

door3.png

door4.png

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

依次为

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.οnlοad=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[i].style.left=imgwidth+exposewidth*(i-1)+'px';

}

}

setImgPos();

var translate=imgwidth-exposewidth;

for(var i=0;i

{

(function(i){

imgs[i].οnmοuseοver=function(){

setImgPos();

for(var j=1;j<=i;j++)

{

imgs[j].style.left=parseInt(imgs[j].style.left,10)-translate+'px';

}

};

})(i);

}

};

弄好后的效果图如下:

48870731fb80874733b1fe3e2fde2593.png

遇到的问题:

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

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

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

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


http://www.ppmy.cn/news/507336.html

相关文章

在 Vue 中实现 sticky 鼠标上滑显示、下滑隐藏的效果

在 Vue 中实现 sticky 鼠标上滑显示、下滑隐藏的效果 首先在需要实现该效果的组件中&#xff0c;创建一个数据属性&#xff0c;例如&#xff1a; isStickyVisible: true&#xff0c;并将其初始值设置为 true。在组件的模板中&#xff0c;使用 v-show 绑定该数据属性&#xff0…

RF UI自动化常见操作问题记录

1、 运行用例之后如何自动关闭浏览器 1、在每个Test_Case的最后面添加Close All Browsers&#xff08;当测试用例执行失败时&#xff0c;则无法关闭浏览器驱动进程&#xff09;2、在用例集上增加 Close All Browsers (用例无论执行成功还是失败都会关闭浏览器&#xff09;2、模…

Appium自动化下拉刷新

使用Appium作app自动化测试&#xff0c;绕不开的就是下拉刷新操作&#xff0c;下拉是最常见的&#xff0c;其实还有上滑、左滑、右滑操作。在正式的测试流程里&#xff0c;可以把刷新操作封装成一个模块&#xff0c;需要时直接调用。 Appium中提供了三种滑动的方式&#xff1a…

自动化测试--16Selenium基本用法-鼠标键盘操作、下拉框操作

1.鼠标操作 由selenium的ActionChains类来完成模拟鼠标操作 主要操作流程: 1.存储鼠标操作 2.perform()来执行鼠标操作 支持的操作如下: double_click 双击操作 context_click 右键操作 drag_and_drop 拖拽操作。左键按住拖动某一个元素到另一个区域,然后释放按键 move_to_…

解决鼠标滚动时页面上下跳动的问题

解决鼠标滚动时页面上下跳动的问题 前言 鼠标用的时间长了&#xff0c;用中间滚轮滚动页面时会出现上下窜动的情况&#xff0c;这一般都是滚轮编码器内有污物导致的。 一、拆开鼠标 1、准备一把螺丝刀和镊子。取下鼠标的电池。鼠标一般都有一个固定螺丝&#xff0c;在下盖上…

web自动化测试理论之浏览器操作 -(3)

浏览器操作 设置浏览器显示范围&#xff1a; 1、窗口最大化 dirver.maxmize_window() 2、设置窗口大小 dirver.set_window_size(width, height) 3、设置窗口位置 dirver.set_window_position(x, y) 浏览器显示页面操作&#xff1a; 1、页面后退操作 dirver.back() 2、…

web自动化学习-鼠标操作及下拉框

鼠标操作 鼠标操作&#xff1a;Action.Chains 分为 操作执行 操作包括但不限于如下几种&#xff1a; 悬浮&#xff1a;move_to_element单击&#xff1a;click双击&#xff1a;double_click点击并按住&#xff1a;click_and_hold 释放 relese拖拽&#xff1a;drag_and_drop执…

java实现鼠标指针匀速下滑,当鼠标移到自动填充柄上,鼠标指针变为( )。

【单选题】完全垄断厂商达于长期均衡的条件是 【单选题】Tant pis ! Tu as fait ______ de fautes que moi dans la dicte. ( ) 【单选题】公式“int(rand()*10)”产生的值不可能是( )。 【判断题】多步骤大量大批生产一般不需要在完工产品与在产品间分配费用。 【多选题】下列…