JS表格分页组件:fupage的设计思路和具体用法(未来考虑开源,争取

pageHolder,存放分页,比如“上一页”、“下一页”等。fuPage.send();解析变量,{varName}。 自定义函数。 比如 <td>@formatStatus({status})</td>function formatStatus(status){ }四、设计思路

/**

* FansUnion Page Library v1.0.7

* LastUpdate:2015-3-13

* Copyright 2012~2112, xiaolei

* QQ: 240370818

* Email:fansunion@qq.com

*

*/

/**

* 分页组件,可以作为自定义内容或者标准型表格的分页,比如文章评论,user列表。 表格分页,,模版由外界传入。

* <br/>提供给用户的构造表格的方法主要有2个:构造方法 new FuPage(options)和发送数据请求send(params)。

* 事件通知方法有:onfilled,onedited,onerror(暂时没有)

*/

function FuPage(options) {

this.url = options.url;

this.params = options.params;

this.startNo = 1;

this.endNo = 1;

this.tableTemplate = options.tableTemplate;

this.bodyHolder = options.bodyHolder;

this.pageHolder = options.pageHolder;

}

// 向后端发送请求

FuPage.prototype.send = function(params) {

var that = this;

// console.log(params);

if (typeof params == ‘object’) {

$.each(params, function(p, val) {

that.params[p] = val;

})

}

console.log("FuPage params:" + that.params);

$.post(this.url, this.params, function(data) {

var page = data.page;

if (!page) {

// console.error("page is null,data is "+data);

data = $.parseJSON(data);

page = data.page;

}

that.renderTable(page);

renderPage(that, page);

addPageEvent(that, page);

});

}

// 渲染表格主体

FuPage.prototype.renderTable = function(page) {

// var ok = this.isTable && this.tableTemplate != null;

if (!this.tableTemplate) {

console.error("tableTemplate is null");

return false;

}

var divs = ”;

$("#" + this.bodyHolder).html(divs);

}

// 未定义的变量,用""展示

var nullToEmpty = function(value) {

if (value == null || value == undefined) {

value = "";

}

return value;

}

// 渲染分页栏

function renderPage(fuPage, page) {

var pageDiv = buildPage(fuPage, page);

$("#" + fuPage.pageHolder).html(pageDiv);

}

// 为分页超链接绑定click事件

function addPageEvent(fuPage, page) {

// 解决同一个页面,多个实例导致ID冲突的问题

var prefix = fuPage.pageHolder;

var nextPageA = document.getElementById(prefix + "nextPageA");

if (nextPageA != null) {

nextPageA.onclick = function() {

goToPage(fuPage, fuPage.params.pageNo + 1)

};

}

var prevPageA = document.getElementById(prefix + "prevPageA");

if (prevPageA != null) {

prevPageA.onclick = function() {

goToPage(fuPage, fuPage.params.pageNo – 1)

}

}

var beginPageA = document.getElementById(prefix + "beginPageA");

if (beginPageA) {

beginPageA.onclick = function() {

goToPage(fuPage, 1);

}

}

var endPageA = document.getElementById(prefix + "endPageA");

if (endPageA != null) {

endPageA.onclick = function() {

goToPage(fuPage, page.totalPage)

}

}

for (var no = fuPage.startNo; no <= fuPage.endNo; no++) {

var id = prefix + "noPageA" + no;

// console.log(id);

var noPageA = document.getElementById(id);

if (noPageA != null && no != fuPage.pageNo) {

$("#" + id).on("click", function(e) {

// 找到事件源,事件源的文本内容"1"即为页数,string转换成int,防止str+int结果是string

var number = $(this).text();

// 把string转换成int类型

number = new Number(number);

goToPage(fuPage, number)

});

}

}

}

// 加载指定的页面

function goToPage(fuPage, no) {

fuPage.params.pageNo = no;

fuPage.send();

}

// 构造分页栏的html,记得给第“1”页等按钮,绑定事件

function buildPage(fuPage, page) {

var totalPage = page.totalPage;

var pageNo = page.pageNo || 1;

var pageSize = page.pageSize;

var totalCount = page.totalCount;

if (totalCount <= 0) {

console.log("totalCount=0")

return "";

}

// 半距离算法

var half = 5;

var startNo = 1;

var endNo = totalPage;

var left = pageNo – half;

var right = pageNo + half;

if (left < 1) {

startNo = 1;

} else {

startNo = left;

}

if (right > totalPage) {

endNo = totalPage;

} else {

endNo = right;

}

fuPage.startNo = startNo;

fuPage.endNo = endNo;

var prefix = fuPage.pageHolder;

// 分页链接,绑定事件

var ul = ‘<ul class="pagination">’;

if (pageNo == 1) {

ul += ‘<li class="disabled"><span>首页</span></li><li><span>上一页</span></li>’;

} else {

ul += ‘<li><a href="javascript:;" id="’ + prefix

+ ‘beginPageA">首页</a></li><li><a href="javascript:;" id="’

+ prefix + ‘prevPageA">上一页</a></li>’;

}

for (var no = startNo; no <= endNo; no++) {

if (no == pageNo) {

ul += ‘<li class="active"><a href="javascript:;">’ + no

+ ‘</a></li>’;

} else {

ul += ‘<li><a href="javascript:;" id="’ + prefix + ‘noPageA’ + no

+ ‘" >’ + no + ‘</a></li>’;

}

}

if (pageNo == totalPage)

ul += ‘<li class="disabled"><span>下一页</span></li><li class="disabled"><span>尾页</span></li>’;

else {

ul += ‘<li><a href="javascript:;" id="’ + prefix

+ ‘nextPageA" >下一页</a></li><li><a href="javascript:;" id="’

+ prefix + ‘endPageA">尾页</a></li>’;

}

ul += ‘<li><span>共’ + totalPage + ‘页</span></li><li><span>共’ + totalCount

+ ‘条</span></li></ul>’;

return ul;

}

山不厌高,水不厌深。

JS表格分页组件:fupage的设计思路和具体用法(未来考虑开源,争取

相关文章:

你感兴趣的文章:

标签云: