21 changed files with 538 additions and 54 deletions
After Width: | Height: | Size: 314 B |
@ -0,0 +1,132 @@ |
|||
#luckysheet-bottom-pager { |
|||
margin-right: 10px; |
|||
float: right; |
|||
} |
|||
.spage-total { |
|||
display: inline-block; |
|||
margin-right: 10px; |
|||
line-height: 29px; |
|||
color: #666; |
|||
font-size: 14px |
|||
} |
|||
|
|||
.spage-number { |
|||
display: inline-block; |
|||
color: #666; |
|||
font-size: 14px |
|||
} |
|||
.selectNum { |
|||
font-size: 14px; |
|||
height: 27px; |
|||
box-sizing: border-box; |
|||
vertical-align: top; |
|||
line-height: 27px; |
|||
border: 1px solid #ddd; |
|||
margin-left: 5px; |
|||
vertical-align: middle; |
|||
} |
|||
.spage-number button { |
|||
position: relative; |
|||
box-sizing: border-box; |
|||
display: inline-block; |
|||
margin-left: -1px; |
|||
padding: 0 10px; |
|||
line-height: 27px; |
|||
border: 1px solid #ddd; |
|||
text-align: center; |
|||
transition: all .2s; |
|||
cursor: pointer; |
|||
outline: none; |
|||
background: 0 0; |
|||
user-select: none; |
|||
color: #333; |
|||
background: #fff; |
|||
vertical-align: middle; |
|||
} |
|||
.prevBtn, .nextBtn { |
|||
width: 16px; |
|||
height: 27px; |
|||
background: url(images/js.png) no-repeat center center; |
|||
background-size: 100% auto; |
|||
display: block; |
|||
transform: rotate(180deg); |
|||
} |
|||
.nextBtn { |
|||
transform: rotate(0); |
|||
} |
|||
.spage-number button.active { |
|||
background: #2d98e6; |
|||
color: #fff; |
|||
border-color: #2d98e6; |
|||
z-index: 3 |
|||
} |
|||
|
|||
.spage-number button.active:hover { |
|||
background: #2d98e6; |
|||
color: #fff; |
|||
border-color: #2d98e6; |
|||
z-index: 3 |
|||
} |
|||
|
|||
.spage-number button:hover { |
|||
background-color: #eee |
|||
} |
|||
|
|||
.spage-number button.button-disabled { |
|||
cursor: not-allowed; |
|||
color: #ccc |
|||
} |
|||
|
|||
.spage-number .spage-after, |
|||
.spage-before { |
|||
padding: 0; |
|||
width: 40px |
|||
} |
|||
|
|||
.spage-skip { |
|||
display: inline-block; |
|||
margin-left: 5px; |
|||
line-height: 27px; |
|||
color: #666; |
|||
font-size: 14px |
|||
} |
|||
|
|||
.spage-skip input { |
|||
box-sizing: border-box; |
|||
display: inline-block; |
|||
width: 45px; |
|||
height: 29px; |
|||
text-align: center; |
|||
vertical-align: top; |
|||
border: 1px solid #ddd; |
|||
background: 0 0; |
|||
outline: none; |
|||
transition: all .2s |
|||
} |
|||
|
|||
.spage-skip input:focus { |
|||
border-color: #2d98e6 |
|||
} |
|||
|
|||
.spage-skip button { |
|||
display: inline-block; |
|||
padding: 0 14px; |
|||
line-height: 27px; |
|||
vertical-align: top; |
|||
color: #333; |
|||
border: 1px solid #ddd; |
|||
cursor: pointer; |
|||
transition: all .2s; |
|||
outline: none; |
|||
background: 0 0; |
|||
user-select: none; |
|||
background-color: #fff; |
|||
} |
|||
|
|||
.spage-skip button:hover { |
|||
background: #2d98e6; |
|||
color: #fff; |
|||
border: 1px solid #2d98e6 |
|||
} |
|||
|
|||
|
@ -0,0 +1,202 @@ |
|||
/* jQuery分页插件sPage version:1.2.2 github:https://github.com/jvbei/sPage */ |
|||
(function (p, t, e, a) { |
|||
"use strict"; |
|||
var s = { |
|||
page: 1, |
|||
pageSize: 200, |
|||
total: 0, |
|||
showTotal: false, |
|||
totalTxt: "共{total}条", |
|||
noData: false, |
|||
showSkip: false, |
|||
showPN: true, |
|||
prevPage: "上一页", |
|||
nextPage: "下一页", |
|||
fastForward: 0, |
|||
selectOption: [], |
|||
backFun: function (t) {} |
|||
}; |
|||
var img = '' |
|||
function i(t, e) { |
|||
this.element = p(t); |
|||
this.settings = p.extend({}, s, e); |
|||
this.pageNum = 1, this.pageList = [], this.pageTatol = 0; |
|||
this.init() |
|||
} |
|||
p.extend(i.prototype, { |
|||
init: function () { |
|||
this.element.empty(); |
|||
this.viewHtml() |
|||
this.clickBtn() |
|||
}, |
|||
creatHtml: function (t) { |
|||
t == this.settings.page ? this.pageList.push('<button class="active" data-page=' + t + ">" + t + "</button>") : this.pageList.push("<button data-page=" + t + ">" + t + "</button>") |
|||
}, |
|||
viewHtml: function () { |
|||
var t = this.settings; |
|||
var e = 0; |
|||
var a = []; |
|||
if (t.total > 0) { |
|||
e = Math.ceil(t.total / t.pageSize) |
|||
} else { |
|||
if (t.noData) { |
|||
e = 1; |
|||
t.page = 1; |
|||
t.total = 0 |
|||
} else { |
|||
return |
|||
} |
|||
} |
|||
this.pageTatol = e; |
|||
this.pageNum = t.page; |
|||
if (t.showTotal) { |
|||
a.push('<div class="spage-total">' + t.totalTxt.replace(/\{(\w+)\}/gi, t.total) + "</div>") |
|||
} |
|||
a.push('<div class="spage-number">'); |
|||
this.pageList = []; |
|||
if (t.showPN) { |
|||
t.page == 1 ? this.pageList.push('<button class="button-disabled" data-page="prev"><i class="prevBtn"></i></button>') : this.pageList.push('<button data-page="prev"><i class="prevBtn"></i></button>') |
|||
} |
|||
if (e <= 6) { |
|||
for (var s = 1; s < e + 1; s++) { |
|||
this.creatHtml(s) |
|||
} |
|||
} else { |
|||
if (t.page < 3) { |
|||
for (var s = 1; s <= 3; s++) { |
|||
this.creatHtml(s) |
|||
} |
|||
this.pageList.push('<button data-page="after" class="spage-after">...</button><button data-page=' + e + ">" + e + "</button>") |
|||
} else if (t.page > e - 3) { |
|||
this.pageList.push('<button data-page="1">1</button><button data-page="before" class="spage-before">...</button>'); |
|||
for (var s = e - 3; s <= e; s++) { |
|||
this.creatHtml(s) |
|||
} |
|||
} else { |
|||
this.pageList.push('<button data-page="1">1</button>'); |
|||
if (t.page > 3) { this.pageList.push('<button data-page="before" class="spage-before">...</button>') } |
|||
for (var s = t.page - 1; s <= Number(t.page) + 1; s++) { |
|||
this.creatHtml(s) |
|||
} |
|||
if (t.page <= e - 3) { this.pageList.push('<button data-page="after" class="spage-after">...</button>') } |
|||
this.pageList.push('<button data-page=' + e + ">" + e + "</button>") |
|||
} |
|||
} |
|||
if (t.showPN) { |
|||
t.page == e ? this.pageList.push('<button class="button-disabled" data-page="next"><i class="nextBtn"></i></button>') : this.pageList.push('<button data-page="next"><i class="nextBtn"></i></button>') |
|||
} |
|||
|
|||
|
|||
|
|||
a.push(this.pageList.join("")); |
|||
a.push("</div>"); |
|||
|
|||
|
|||
if (t.selectOption.length > 0) { |
|||
var str = '<select class="selectNum" id="selectNum">' |
|||
for (var i = 0; i <= t.selectOption.length - 1; i++) { |
|||
str += '<option value=' + t.selectOption[i] + ' ' |
|||
if (t.pageSize === t.selectOption[i]) { |
|||
str += 'selected' + '>' + t.selectOption[i] + '行/页</option>' |
|||
} else { |
|||
str += '>' + t.selectOption[i] + '行/页</option>' |
|||
} |
|||
} |
|||
str += '</select>' |
|||
a.push(str); |
|||
} |
|||
if (t.showSkip) { |
|||
a.push('<div class="spage-skip">跳至 <input type="text" class="luckysheet-mousedown-cancel" value="' + t.page + '"/> 页 </div>') |
|||
} |
|||
|
|||
this.element.html(a.join("")); |
|||
|
|||
|
|||
|
|||
}, |
|||
clickBtn: function () { |
|||
var a = this; |
|||
var s = this.settings; |
|||
var i = this.element; |
|||
var n = this.pageTatol; |
|||
this.element.on('change', 'select', function (e) { |
|||
var value = parseInt(document.getElementById('selectNum').value) |
|||
s.pageSize = value |
|||
s.page = 1 |
|||
a.element.empty(); |
|||
a.viewHtml() |
|||
s.backFun(s) |
|||
}) |
|||
this.element.off("click", "button"); |
|||
this.element.on("click", "button", function () { |
|||
var t = p(this).data("page"); |
|||
switch (t) { |
|||
case "prev": |
|||
s.page = s.page - 1 >= 1 ? s.page - 1 : 1; |
|||
t = s.page; |
|||
break; |
|||
case "next": |
|||
s.page = Number(s.page) + 1 <= n ? Number(s.page) + 1 : n; |
|||
t = s.page; |
|||
break; |
|||
case "before": |
|||
s.page = s.page - s.fastForward >= 1 ? s.page - s.fastForward : 1; |
|||
t = s.page; |
|||
break; |
|||
case "after": |
|||
s.page = Number(s.page) + Number(s.fastForward) <= n ? Number(s.page) + Number(s.fastForward) : n; |
|||
t = s.page; |
|||
break; |
|||
case "go": |
|||
var e = parseInt(i.find("input").val()); |
|||
if (/^[0-9]*$/.test(e) && e >= 1 && e <= n) { |
|||
s.page = e; |
|||
t = e |
|||
} else { |
|||
return |
|||
} |
|||
break; |
|||
default: |
|||
s.page = t |
|||
} |
|||
if (t == a.pageNum) { |
|||
return |
|||
} |
|||
a.pageNum = s.page; |
|||
a.viewHtml(); |
|||
s.backFun(s) |
|||
}); |
|||
this.element.off("keyup", "input"); |
|||
this.element.on("keyup", "input", function (t) { |
|||
if (t.keyCode == 13) { |
|||
var e = parseInt(i.find("input").val()); |
|||
if (/^[0-9]*$/.test(e) && e >= 1 && e <= n && e != a.pageNum) { |
|||
s.page = e; |
|||
a.pageNum = e; |
|||
a.viewHtml(); |
|||
s.backFun(s) |
|||
} else { |
|||
return |
|||
} |
|||
} |
|||
}); |
|||
if (s.fastForward > 0) { |
|||
i.find(".spage-after").hover(function () { |
|||
p(this).html("»") |
|||
}, function () { |
|||
p(this).html("...") |
|||
}); |
|||
i.find(".spage-before").hover(function () { |
|||
p(this).html("«") |
|||
}, function () { |
|||
p(this).html("...") |
|||
}) |
|||
} |
|||
} |
|||
}); |
|||
p.fn.sPage = function (t) { |
|||
return this.each(function () { |
|||
new i(this, t) |
|||
}) |
|||
} |
|||
})(jQuery, window, document); |
Loading…
Reference in new issue