JS实现长图上下滚动效果


Posted in Javascript onMarch 19, 2020

本文实例为大家分享了JS实现长图上下滚动的具体代码,供大家参考,具体内容如下

案例描述

将一张长图放在某一固定长宽的盒子里,当鼠标置于盒子的上半部分时,图片向下滑直到到达图片的底部停止;当鼠标置于盒子的下半部分时,图片向上滑直到到达图片的顶部停止。

案例图示

JS实现长图上下滚动效果

HTML

<div id="box">
 <img id="pic" src="./program1/images/1.jpg" alt="">
 <div id="top"></div>
<div id="bottom"></div>

CSS

CSS不作过多解释,详解请看注释部分

//通用样式
 * {
 margin: 0;
 padding: 0;
 }
 #box {
 width: 750px;
 height: 200px;
 border: 1px solid #000;
 margin: 200px auto;
 overflow: hidden; /*图片溢出部分隐藏*/
 position: relative; /*子绝父相*/
 }

 #pic {
 position: absolute;
 left: 0;
 right: 0;
 }

 
 #top {
 width: 100%;
 height: 50%;
 position: absolute; /*子绝父相*/
 left: 0;
 cursor: pointer; /*鼠标*/
  /* 顶部对齐 */
 top:0; 
 }
 
 #bottom {
 width: 100%;
 height: 50%;
 position: absolute; /*子绝父相*/
 left: 0;
 cursor: pointer;
 /* 底部对齐 */
 bottom: 0;
 }
</style>

JS核心代码

JS详解----监听鼠标进入事件(以盒子上半部分为例)

鼠标停留在盒子上半部分时,使用onmouseover事件。首先要清除定时器,否则可能会出现定时器重叠现象;再设置定时器,定时器中的num就是改变图片的top属性以达到图片向上滑动的效果。if语句中的条件是为了达到图片到达底部时停止向上滑的目的。(盒子下半部分类似)

top.onmouseover = function(){
  // 改变pic中的top 
  // 清除定时器
  // alert(0);
  clearInterval(intervalId);

  // 设置定时器 
  intervalId = setInterval(function(){
  if(num > -600){
   num -= 10;
   pic.style.top = num + "px";
  }
  
  },20);

JS详解----监听鼠标移出事件(以盒子上半部分为例)

鼠标移出时使用onmouseout事件,清除定时器。(盒子下半部分类似)

top.onmouseout = function() {
  clearInterval(intervalId);
 }

JS全部代码展示

<script>
 window.onload = function() {
 // 获取标签
 var box = document.getElementById('box');
 var pic = document.getElementById('pic');
 var top = document.getElementById('top');
 var bottom = document.getElementById('bottom');
 var intervalId, num = 0;
 // 鼠标进入上半部分
 top.onmouseover = function(){
  // 改变pic中的top 
  // 清除定时器
  // alert(0);
  clearInterval(intervalId);

  // 设置定时器
  intervalId = setInterval(function(){
  if(num > -600){
   num -= 10;
   pic.style.top = num + "px";
  }
  
  },20);

 };
  // 鼠标移出上半部分
 top.onmouseout = function() {
  clearInterval(intervalId);
 }
 // 鼠标进入下半部分
 bottom.onmouseover = function(){
  // 改变pic中的top 
  // 清除定时器
  // alert(0);
  clearInterval(intervalId);

  // 设置定时器
  intervalId = setInterval(function(){
  if(num < 0){
   num += 10;
   pic.style.top = num + "px";
  }
  
  },20);
 };
 // 鼠标移出下半部分
 bottom.onmouseout = function() {
  clearInterval(intervalId);
 };
 
 }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
绑定回车enter事件代码
May 18 Javascript
js获取会话框prompt的返回值的方法
Jan 10 Javascript
js+html5实现canvas绘制网页时钟的方法
May 21 Javascript
微信小程序 实战小程序实例
Oct 08 Javascript
jQuery实现动态添加tr到table的方法
Dec 26 Javascript
用move.js库实现百叶窗特效
Feb 08 Javascript
TableSort.js表格排序插件使用方法详解
Feb 10 Javascript
jQuery实现弹窗居中效果类似alert()
Feb 27 Javascript
详解vue-cli项目中的proxyTable跨域问题小结
Feb 09 Javascript
Express进阶之log4js实用入门指南
Feb 10 Javascript
D3.js实现简洁实用的动态仪表盘的示例
Apr 04 Javascript
JS中比较两个Object数组是否相等方法实例
Nov 11 Javascript
JavaScript实现简单计算器
Mar 19 #Javascript
jQuery实现颜色打字机的完整代码
Mar 19 #jQuery
webpack 动态批量加载文件的实现方法
Mar 19 #Javascript
vue-cli3项目升级到vue-cli4 的方法总结
Mar 19 #Javascript
js实现经典贪吃蛇小游戏
Mar 19 #Javascript
javascrpt密码强度校验函数详解
Mar 18 #Javascript
Node.js Domain 模块实例详解
Mar 18 #Javascript
You might like
php中3des加密代码(完全与.net中的兼容)
2012/08/02 PHP
php使用json_encode对变量json编码
2014/04/07 PHP
JS类定义原型方法的两种实现的区别评论很多
2007/09/12 Javascript
jquery ajax中使用jsonp的限制解决方法
2013/11/22 Javascript
JS获取随机数函数可自定义最小值最大值
2014/05/08 Javascript
多个checkbox被选中时如何判断是否有自己想要的
2014/09/22 Javascript
JavaScript事件委托技术实例分析
2015/02/06 Javascript
jQuery数据缓存用法分析
2015/02/20 Javascript
JS和css实现检测移动设备方向的变化并判断横竖屏幕
2015/05/25 Javascript
Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案
2018/05/15 Javascript
使用vue-router完成简单导航功能【推荐】
2018/06/28 Javascript
使用angular-cli webpack创建多个包的方法
2018/10/16 Javascript
Vuex 使用 v-model 配合 state的方法
2018/11/13 Javascript
npm qs模块使用详解
2020/02/07 Javascript
详解Vue.js 响应接口
2020/07/04 Javascript
vue-simple-uploader上传成功之后的response获取代码
2020/09/07 Javascript
vue使用canvas实现移动端手写签名
2020/09/22 Javascript
python实现探测socket和web服务示例
2014/03/28 Python
在Python中使用CasperJS获取JS渲染生成的HTML内容的教程
2015/04/09 Python
Python实现简易版的Web服务器(推荐)
2018/01/29 Python
Python编程求质数实例代码
2018/01/31 Python
python实现图片彩色转化为素描
2019/01/15 Python
python nmap实现端口扫描器教程
2020/05/28 Python
Python queue队列原理与应用案例分析
2019/09/27 Python
Python常用模块sys,os,time,random功能与用法实例分析
2020/01/07 Python
matlab灰度图像调整及imadjust函数的用法详解
2020/02/27 Python
网络工程师面试(三木通信技术有限公司)
2013/06/05 面试题
外企测试工程师面试题
2015/02/01 面试题
信用社实习人员自我鉴定
2013/09/20 职场文书
文明学生标兵事迹
2014/01/21 职场文书
本科毕业生应聘自荐信范文
2014/06/26 职场文书
应届毕业生求职信范文
2014/07/07 职场文书
公司财务会计主管应聘求职信
2014/09/26 职场文书
学校少先队工作总结
2015/08/12 职场文书
jQuery class属性操作addClass()与removeClass()、hasClass()、toggleClass()
2021/03/31 jQuery
PHP判断是否是json字符串
2021/04/01 PHP