`

jQuery AJAX 分页插件

阅读更多
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>simplePage</title>
<style type="text/css">
html,body{ margin:0 auto; text-align:center; }
.main{ font:12px/24px "Microsoft YaHei"; height:1000px; }
#page{ margin:100px auto; width:960px; text-align:center; }
#page a{ text-decoration:none; display:inline-block; height:24px; padding:0 8px; border-radius:3px; background-color:#DEF39E; color:#8CAC2C; text-align:center; margin:0 2px; }
#page a:hover,#page .now{ background-color:#8CAC2C; color:#fff; transition:all .5s ease 0s; }
</style>
</head>

<body>
<div class="main">
	<div id="page">
		<!-- 
		<a href="#3">上一页</a>
		<a href="#4">4</a>
		<a href="#5">5</a>
		<a href="#6" class="now">6</a>
		<a href="#7">7</a>
		<a href="#8">8</a>
		<a href="#9">下一页</a>
		 -->
	</div>
	<div class="back"></div>
</div>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript">

$(function(){
	$.simplePage({
		obj : "#page",
		current : "now",
		nowNum : 1,
		allNum : 20,
		pageSize : 5,
		callBack : function(now, all){
			$(".back").html(now + "-" + all);
		}
	});
});
/*!
 * jQuery simple page plus v1.1
 * http://www.imsole.net/
 * Author:sole
 * Created:2012/10/31 upd 2013/10/15
*/
$.extend({
	simplePage : function(opt){

		if(!opt.obj){ return false; };
		var obj = $(opt.obj); 
		var cls = opt.current;
		var nowNum = opt.nowNum || 1; 
		var allNum = opt.allNum || 5; 
		var pageSize = opt.pageSize || 5;
		var callBack = opt.callBack || function(){};
		var apd_ele = "";
		var pagecenter = pageSize%2 == 0 ? pageSize/2 : (pageSize+1)/2;
		
		function ele(num, cls){
			var str = "";
			if(cls){
				str = "<a href='#"+num+"' class='"+cls+"'>"+num+"</a>";
			}else{
				str = "<a href='#"+num+"'>"+num+"</a>";
			}
			return str;
		}

		if(nowNum > 1){
			apd_ele = "<a href='#"+ ( nowNum - 1 ) +"'>上一页</a>";
			obj.append(apd_ele);
		}

		if(allNum <= pageSize){
			for(var i=1; i<=allNum; i++){
				if(nowNum == i){
					apd_ele = ele(i, cls);
				}else{
					apd_ele = ele(i);
				}
				obj.append(apd_ele);
			}
		}else{
			for(var i=1; i<=pageSize; i++){
				if(nowNum == 1 || nowNum == 2){
					if(nowNum == i){
						apd_ele = ele(i, cls);
					}else{
						apd_ele = ele(i);
					}
				}else if( (allNum - nowNum) == 0 || (allNum - nowNum) == 1 ){
					if( (allNum - nowNum) == 0 && i == pageSize){
						apd_ele = ele( (allNum - pageSize + i), cls);
					}else if( (allNum - nowNum) == 1 && i == pageSize-1){
						apd_ele = ele( (allNum - pageSize + i), cls);
					}else{
						apd_ele = ele( allNum - pageSize + i );
					}
				}else{
					if(i == pagecenter){
						apd_ele = ele(nowNum-pagecenter+i, cls);
					}else{
						apd_ele = ele(nowNum-pagecenter+i);
					}
				}
				
				obj.append(apd_ele);
			}
		}

		if((allNum - nowNum) >= 1){
			apd_ele = "<a href='#"+ ( nowNum + 1 ) +"'>下一页</a>";
			obj.append(apd_ele);
		}
		
		callBack(nowNum, allNum);

		$("a", obj).click(function(){
			var url = $(this).attr("href");
			var nowNum = url.match(/#\d+/g)+'';
			nowNum = parseInt(nowNum.substring(1));
			obj.html("");
			$.simplePage({
				obj : obj,
				current : cls,
				nowNum : nowNum,
				allNum : allNum,
				pageSize : pageSize,
				callBack :callBack
			});
			return false;
		});
	}
});

</script>
</body>
</html>
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics