利用jQuery简单实现产品展示图片左右滚动功能(示例代码)


Posted in Javascript onJanuary 02, 2014

最近要做一个产品展示功能,由于产品比较多,一屏展示不完,所以想要做一个通过点击进行翻页的效果,在网上找了几个都不大好用,最后只能自己动手写了。

效果如下所示:

利用jQuery简单实现产品展示图片左右滚动功能(示例代码)

原理比较简单:将要滚动显示的区域的CSS的override设为hidden,宽度设成一个比较大的值,如4000px,然后每次点击上一页或下一页的按钮时,计算当前页数,如果已经到了最后一页,则回到第一页,滚动是通过控制div的left属性实现的,需要两个div,外面的div的position设为retative,里面的DIV的position设为absolute。

主要代码如下:

HTML:

<div id="product">
 <h2><span class="arrow">arrow</span>产品展示</h2>
 <span class="prev"></span>
 <div id="content">
 <div id="content_list">
 <dl>
  <dt><img src="images/product1.jpg"/></dt>
  <dd>数据采集移动终端</dd>
 </dl>
 <dl>
  <dt><img src="images/product2.jpg"/></dt>
  <dd>数据采集移动终端</dd>
 </dl>
 <dl>
  <dt><img src="images/product3.jpg"/></dt>
  <dd>数据采集移动终端</dd>
 </dl>
 <dl>
  <dt><img src="images/product3.jpg"/></dt>
  <dd>数据采集移动终端</dd>
 </dl>
 <dl>
  <dt><img src="images/product1.jpg"/></dt>
  <dd>数据采集移动终端1</dd>
 </dl>
 <dl>
  <dt><img src="images/product1.jpg"/></dt>
  <dd>数据采集移动终端1</dd>
 </dl>
 <dl>
  <dt><img src="images/product1.jpg"/></dt>
  <dd>数据采集移动终端1</dd>
 </dl>
 </div>
 </div>
 <span class="next"></span>
</div>

CSS:
#product {
 width:720px;
 height:200px;
 border:1px solid #ccc;
 margin:0 5px 5px 0;
 float:left;
}
#product div#content {
 position:relative;
 width:690px;
 height:160px;
 display:inline-block;
 overflow:hidden;
 float:left;
}
#product div#content_list {
 position:absolute;
 width:4000px;
}
#product dl{
 width:160px;
 height:150px;
 float:left;
 margin:10px 4px;
 padding:2px 2px;
}
#product dl:hover {
 border:1px solid #333;
 background:#ccc;
}
#product dl dt {}
#product dl dt img {
 width:160px;
 height:120px;
 border:none;
}
#product dl dd {
 text-align:center;
}
#product span.prev{
 cursor:pointer;
 display:inline-block;
 width:15px;
 height:150px;
 background:url(../images/arrow_l.gif) no-repeat left center;
 float:left;
}
#product span.next{
 cursor:pointer;
 display:inline-block;
 width:15px;
 height:150px;
 background:url(../images/arrow_r.gif) no-repeat left center;
 float:right;
}

js代码
$(function(){
    var page = 1;
    var i = 4; //每版放4个图片
    //向后 按钮
    $("span.next").click(function(){    //绑定click事件
   var content = $("div#content"); 
   var content_list = $("div#content_list");
   var v_width = content.width();
   var len = content.find("dl").length;
   var page_count = Math.ceil(len / i) ;   //只要不是整数,就往大的方向取最小的整数
   if( !content_list.is(":animated") ){    //判断“内容展示区域”是否正在处于动画
     if( page == page_count ){  //已经到最后一个版面了,如果再向后,必须跳转到第一个版面。
    content_list.animate({ left : '0px'}, "slow"); //通过改变left值,跳转到第一个版面
    page = 1;
     }else{
    content_list.animate({ left : '-='+v_width }, "slow");  //通过改变left值,达到每次换一个版面
    page++;
    }
   }
   });
    //往前 按钮
    $("span.prev").click(function(){
      var content = $("div#content"); 
   var content_list = $("div#content_list");
   var v_width = content.width();
   var len = content.find("dl").length;
   var page_count = Math.ceil(len / i) ;   //只要不是整数,就往大的方向取最小的整数
   if(!content_list.is(":animated") ){    //判断“内容展示区域”是否正在处于动画
     if(page == 1 ){  //已经到第一个版面了,如果再向前,必须跳转到最后一个版面。
     content_list.animate({ left : '-='+v_width*(page_count-1) }, "slow");
    page = page_count;
   }else{
    content_list.animate({ left : '+='+v_width }, "slow");
    page--;
   }
  }
    });
});
Javascript 相关文章推荐
JavaScript中的函数模式详解
Feb 11 Javascript
Webpack 实现 Node.js 代码热替换
Oct 22 Javascript
jQuery焦点图轮播插件KinSlideshow用法分析
Jun 08 Javascript
JS实现小球的弹性碰撞效果
Nov 11 Javascript
Vue cli+mui 区域滚动的实例代码
Jan 25 Javascript
解决vue props 拿不到值的问题
Sep 11 Javascript
vuejs router history 配置到iis的方法
Sep 20 Javascript
使用JavaScript解析URL的方法示例
Mar 01 Javascript
jquery-ui 进度条功能示例【测试可用】
Jul 25 jQuery
Node.js+Vue脚手架环境搭建的方法步骤
Mar 08 Javascript
JavaScript canvas实现跟随鼠标移动小球
Feb 09 Javascript
vue中this.$http.post()跨域和请求参数丢失的解决
Apr 08 Vue.js
使用简洁的jQuery方法实现隔行换色功能
Jan 02 #Javascript
快速解决jQuery与其他库冲突的方法介绍
Jan 02 #Javascript
js/jQuery简单实现选项卡功能
Jan 02 #Javascript
jQuery(js)获取文字宽度(显示长度)示例代码
Dec 31 #Javascript
js判断字符长度以及中英文数字等
Dec 31 #Javascript
checkbox全选所涉及到的知识点介绍
Dec 31 #Javascript
用js+iframe形成页面的一种遮罩效果的具体实现
Dec 31 #Javascript
You might like
php计算几分钟前、几小时前、几天前的几个函数、类分享
2014/04/09 PHP
php操作memcache缓存方法分享
2015/06/03 PHP
100多行PHP代码实现socks5代理服务器[2]
2016/05/05 PHP
PHP中多线程的两个实现方法
2016/10/14 PHP
PHP简单实现防止SQL注入的方法
2018/03/13 PHP
JS IE和FF兼容性问题汇总
2009/02/09 Javascript
小议Javascript中的this指针
2010/03/18 Javascript
JavaScript中的细节分析
2012/06/30 Javascript
如何获取网站icon有哪些可行的方法
2014/06/05 Javascript
JavaScript操作Oracle数据库示例
2015/03/06 Javascript
jQuery实现图片上传和裁剪插件Croppie
2015/11/29 Javascript
Javascript之Date对象详解
2016/06/07 Javascript
jQuery实现点击后高亮背景固定显示的菜单效果【附demo源码下载】
2016/09/21 Javascript
jQuery实现ajax无刷新分页页码控件
2017/02/28 Javascript
JavaScript获取tr td 的三种方式全面总结(推荐)
2017/08/15 Javascript
React+EggJs实现断点续传的示例代码
2020/07/07 Javascript
使用js和canvas实现时钟效果
2020/09/08 Javascript
浅析Python中的join()方法的使用
2015/05/19 Python
利用 python 对目录下的文件进行过滤删除
2017/12/27 Python
python将文本中的空格替换为换行的方法
2018/03/19 Python
Python爬取成语接龙类网站
2018/10/19 Python
Python判断变量名是否合法的方法示例
2019/01/28 Python
python pandas写入excel文件的方法示例
2019/06/25 Python
python列表生成器迭代器实例解析
2019/12/19 Python
Python 实现敏感目录扫描的示例代码
2020/05/21 Python
SmartBuyGlasses中国:唯视良品(销售名牌太阳镜、墨镜和眼镜框)
2017/07/03 全球购物
Linux内核产生并发的原因
2012/07/13 面试题
介绍一下linux的文件系统
2015/10/06 面试题
前台文员职责范本
2014/03/07 职场文书
党员领导干部民主生活会批评与自我批评发言
2014/09/28 职场文书
11.9消防日宣传标语
2014/10/08 职场文书
课外活动总结
2015/02/04 职场文书
义卖募捐活动总结
2015/05/09 职场文书
首席执行官观后感
2015/06/03 职场文书
2016年“七一建党节”广播稿
2015/12/18 职场文书
Redis基于Bitmap实现用户签到功能
2021/06/20 Redis