源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2021-06-23 09:39 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:利用jQuery简单实现产品展示图片左右滚动功能(示例代码)
最近要做一个产品展示功能,由于产品比较多,一屏展示不完,所以想要做一个通过点击进行翻页的效果,在网上找了几个都不大好用,最后只能自己动手写了。 [b]效果如下所示: [/b] [img]http://files.jb51.net/file_images/article/201401/20140102092128.png[/img] [b]原理比较简单:[/b]将要滚动显示的区域的CSS的override设为hidden,宽度设成一个比较大的值,如4000px,然后每次点击上一页或下一页的按钮时,计算当前页数,如果已经到了最后一页,则回到第一页,滚动是通过控制div的left属性实现的,需要两个div,外面的div的position设为retative,里面的DIV的position设为absolute。 主要代码如下: HTML:
[u]复制代码[/u] 代码如下:
<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:
[u]复制代码[/u] 代码如下:
#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代码
[u]复制代码[/u] 代码如下:
$(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--;    }   }     }); });
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部