Jquery制作可以绑定的表格
//总页数 当前页 可见页 参数 翻页执行后处理的函数
function PageTable(totalPages, currentPage, tableobj, url, where, columns) {
function PageTableAjax() {
initTable(tableobj);
$.ajax({
type: "POST",
url: url,
data: { where: where, page: currentPage },
dataType: "json",
success: function (rsp) {
if (rsp.pass) {
totalPages = rsp.pagination.PageCount;
currentPage = rsp.pagination.PageIndex;
bindTable(tableobj, rsp.rows, columns)
console.log("PageTablePaginator")
PageTablePaginator();
} else {
console.log(rsp.msg)
}
},
error: function (e, s, t) {
console.log("ajax error")
}
});
}
function PageTablePaginator() {
$.jqPaginator('ul.pagination', {
wrapper: '',
first: '<li class="first"><a href="javascript:;">首页</a></li>',
prev: '<li class="prev"><a href="javascript:;">«</a></li>',
next: '<li class="next"><a href="javascript:;">»</a></li>',
last: '<li class="last"><a href="javascript:;">尾页</a></li>',
page: '<li class="page"><a href="javascript:;">{{page}}</a></li>',
totalPages: totalPages,/*总数 */
visiblePages: 5,/*可见分页数*/
currentPage: currentPage,
onPageChange: function (num, type) {
if (type == "change") {
console.log('PageTableAjax')
PageTable(totalPages, num, tableobj, url, where, columns)
}
}
});
}
PageTableAjax();
}
//table初始化状态
function initTable(obj) {
console.log('initTable')
var head = $(obj).find('thead tr th');
var tbody = $(obj).find('tbody');
tbody.html("");
//无记录
var tr01 = $("<tr align=\"center\"></tr>");
$("<td colspan=\"" + head.length + "\">loading...</td>").appendTo(tr01);
tbody.append(tr01);
console.log('pagination:' + $('ul.pagination').length)
if ($('ul.pagination').length == 0) {
$(obj).after("<ul class=\"pagination\"></ul>");
}
}
function bindTable(obj, rows, columns) {
console.log('bindTable')
var tbody = $(obj).find('tbody');
tbody.html("");
var head = $(obj).find('thead tr th');
console.log("columns:" + columns.length);
if (rows[0] != 'undefined' && rows[0] != null) { for (var i = 0; i < rows.length; i++) {
var r = rows[i];
var tr = $("<tr></tr>");
for (var j = 0; j < columns.length; j++) {
var fieldstr = columns[j].field;
var valstr = r[fieldstr];
if (fieldstr.indexOf('.') != -1) {
//console.log("indexOf:" + fieldstr.substring(fieldstr.indexOf('.'), fieldstr.length))
var arr = fieldstr.split(".");
valstr = r[arr[0]][arr[1]];
switch(arr.length)
{
case 2:
valstr = r[arr[0]][arr[1]];
break;
case 3:
valstr = r[arr[0]][arr[1]][arr[2]];
break;
case 4:
valstr = r[arr[0]][arr[1]][arr[2]][arr[3]];
break;
default:
valstr = r[arr[0]][arr[1]];
}
} if (columns[j].formatter != 'undefined' && typeof columns[j].formatter === 'function') {
console.log('columns.formatter')
valstr = columns[j].formatter(valstr, i);
}
$("<td>" + valstr + "</td>").appendTo(tr);
}
tbody.append(tr);
}
} else { //无记录
var tr = $("<tr align=\"center\"></tr>");
$("<td colspan=\"" + head.length + "\">(暂无相关记录)</td>").appendTo(tr);
tbody.append(tr);
}
}
花费的时间有限,基本就是为了实现功能。
里面的分页插件是是使用了这个:http://www.oschina.net/p/jqpaginator
使用方法如下:
PageTable(10, 1, "#actionlist", "/Admin/ActionList", where,
[{
field: "Id", formatter: function (val, rec) {
return "<input name=\"aid\" type=\"checkbox\" value=\""+val+"\">";
}
},
{ field: "Id" },
{ field: "ActionName" },
{ field: "ActionUrl" },
{ field: "ActionGroupName" },
{
field: "Id", formatter: function (val, rec) {
return "<a href=\"javascrip:;\" onclick=\"loadContent('/Admin/ActionUpdate?aid=" + val + "',true)\">修改</a>";
}
}])
页面如下:
<table id="actionlist" class="pure-table pure-table-bordered">
<thead>
<tr>
<th><input name="aid_g" type="checkbox" title="全选/反选"></th>
<th>#</th>
<th>命令名</th>
<th>命令参数</th>
<th>分组名</th>
<th>操作</th>
</tr>
</thead> <tbody> </tbody>
</table>
解释如下:函数PageTable有如下参数
totalPages, currentPage, tableobj, url, where, columns(总页数,目标页,表格对象,请求的url,相关查询参数,还有字段列)
我后端是C#用MVC的Json返回:
return Json(new { rows = itemList, pagination = pageturn ,pass=true})
一个匿名对象:rows是行数据,pagination的分页数据,pass是告知数据是否正确。
函数的结构:PageTable函数是入口,先执行PageTableAjax函数,初始化表格(initTable函数)在请求数据,数据接收后,通知bindTable函数绑定数据,再通知PageTablePaginator函数绑定分页。最后在PageTablePaginator函数的每个分页绑定PageTable,达到分页的效果。
效果图如上,表格我是用pure的table样式,还不错。分页的样式是参考bootstrap,然后仔细修改,毕竟bootstrap的css文件太大,不如pure小巧(只有5KB)
Jquery制作可以绑定的表格的更多相关文章
- JQuery Easy Ui dataGrid 数据表格 ---制作查询下拉菜单
JQuery Easy Ui dataGrid 数据表格 数据表格 - DataGrid 继承$.fn.panel.defaults,使用$.fn.datagrid.defaults重载默认值.. 数 ...
- JQuery制作网页——第五章 初识 jQuery
1.jQuery简介: ● jQuery由美国人John Resig于2006年创建 ● jQuery是目前最流行的JavaScript程序库,它是对JavaScript对象和函数的封装 ● 它的设计 ...
- jQuery动态增删改查表格信息,可左键/右键提示
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 使用Vue.js制作仿Metronic高级表格(一)静态设计
Metronic高级表格是Metonic框架中自行实现的表格,其底层是Datatables.本教程将主要使用Vue实现交互部分,使用Bootstrap做样式库.jQuery做部分用户交互(弹窗). 使 ...
- jQuery制作弹出窗(模态框)
来源:(二少)在南极 ##index.html <!DOCTYPE html><html lang="zh"><head> <meta c ...
- 解密jQuery事件核心 - 绑定设计(一)
说起jQuery的事件,不得不提一下Dean Edwards大神 addEvent库,很多流行的类库的基本思想从他那儿借来的 jQuery的事件处理机制吸取了JavaScript专家Dean Edwa ...
- jquery制作论坛或社交网站的每天打卡签到特效
效果:http://hovertree.com/texiao/jquery/50/ 现在许多社区,购物等网站都设置签到功能,打开可以收获经验.虚拟币等,提高用户粘性,增加浏览量,是一个不错的功能.本文 ...
- 如何使用jQuery 制作全屏幕背景的嵌入视频
实际效果查看:http://keleyi.com/keleyi/phtml/jqtexiao/28.htm 请使用支持HTML5的浏览器查看本效果. 完整代码如下: <!doctype html ...
- 关于Jquery的delegate绑定事件无效
今天在做一个页面,用的是easyui页面有很多的tabs,里面都放了iframe 需要在load事件动态调整iframe高度 发现始终无法使用delegate来绑定load事件. 纠结了一下午发现了问 ...
随机推荐
- [转] iOS开发之使用lipo命令制作模拟器与真机通用静态库
转自 http://blog.csdn.net/jinglijun/article/details/8276089 通常在项目中使用静态库的时候都会有两个版本,一个用于模拟器,一个用于真机,因为Mac ...
- fw:理解RESTful架构
理解RESTful架构 作者: 阮一峰 日期: 2011年9月12日 越来越多的人开始意识到,网站即软件,而且是一种新型的软件. 这种"互联网软件"采用客户端/服务器模式,建立 ...
- DFS与BFS
顾名思义,DFS就是一直在一个方向搜索,当这一方向不可以时退回该点,换下一方向: 而BFS一开始就是向四面八方搜索,把符合条件的点存入队列中,当前一个点都搜索完毕时,再从队列顶中取出点,再向四面八方搜 ...
- ubuntu设置vim语法高亮显示和自动缩进
转自:http://nichael1983.blog.163.com/blog/static/114969433201002711850604/ 今天自己学习使用vim,当我在vim中输入程序时,默认 ...
- GlusterFS特性介绍
下面是GlusterFS的一些特性 规范的接口 GlusterFS服务器与POSIX兼容,使用支持文件扩展属性的磁盘文件系统(如ext4.XFS)来存储磁盘上的数据.同时,可以通过业界标准的访问协议如 ...
- 在使用 百度编辑器 Ueditor 时,不能进入 Controller 相应的 Action 的处理方法
如果在前端的页面中使用了 Ueditor 编辑器,那么在提交表单数据时,将不会执行 期望的 Controller 中的 Action ,造成这样的原因是: 在 MVC 4 的框架中,当前端页面需要提交 ...
- javascript设计模式-外观模式
也可译为门面模式.它为子系统中的一组接口提供一个一致的界面, Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用.引入外观角色之后,使用者只需要直接与外观角色交互,使用者与子系统之 ...
- zedboard如何从PL端控制DDR读写(二)——AXI总线
虽然Xilinx已经将和AXI时序有关的细节都封装起来,给出了官方IP和向导生成自定义IP,用户只需要关注自己的逻辑实现,但是还是有必要简单了解一下AXI的时序,毕竟咱是做硬件设计的. AXI(Ad ...
- HttpClient入门
HttpClient入门 HttpClient 是 Apache Jakarta Common 下的子项目,可以用来提供高效的.最新的.功能丰富的支持 HTTP 协议的客户端编程工具包,并且它支持 H ...
- MVC 项目 在前台使用DataTable
1:后台控制器代码 //CreateTestOutputDataHeader生成一个测试DataTable public ActionResult UseDataTable() { DataTable ...