/* 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('') : this.pageList.push('') } 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(''); for (var s = e - 3; s <= e; s++) { this.creatHtml(s) } } else { this.pageList.push(''); if (t.page > 3) { this.pageList.push('') } for (var s = t.page - 1; s <= Number(t.page) + 1; s++) { this.creatHtml(s) } if (t.page <= e - 3) { this.pageList.push('') } this.pageList.push('') : this.pageList.push('') } a.push(this.pageList.join("")); a.push(""); if (t.selectOption.length > 0) { var str = '' a.push(str); } if (t.showSkip) { a.push('
跳至  页  
') } 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);