利用jQuery简单实现产品展示图片左右滚动功能(示例代码)
利用jQuery简单实现产品展示图片左右滚动功能(示例代码)
发布时间:2016-12-30 来源:查字典编辑
摘要:最近要做一个产品展示功能,由于产品比较多,一屏展示不完,所以想要做一个通过点击进行翻页的效果,在网上找了几个都不大好用,最后只能自己动手写了...

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

效果如下所示:

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

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

主要代码如下:

HTML:

复制代码 代码如下:

<div id="product">

<h2><span>arrow</span>产品展示</h2>

<span></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></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教程学习
编程开发子分类