问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

ligerui如何后台导出excel

发布网友 发布时间:2022-04-23 03:10

我来回答

2个回答

懂视网 时间:2022-04-23 07:31

这次给大家带来jQuery LigerUI操作表格,jQuery LigerUI操作表格的注意事项有哪些,下面就是实战案例,一起来看一下。

简介

ligerGrid是ligerui系列插件的核心控件,用户可以快速地创建一个美观,而且功能强大的表格,支持排序、分页、多表头、固定列等等。
支持本地数据和服务器数据(配置data或者url)
支持排序和分页(包括Javascript排序和分页)
支持列的“显示/隐藏”
支持多表头
支持固定列
支持明细行
支持汇总行
支持单元格模板
支持编辑表格(三种编辑模式,单元格编辑、行编辑、明细编辑)
支持树表格
支持分组
代码
首先引入基本的css和js文件

<link href="http://www.cnblogs.com/lib/ligerUI/skins/Aqua/css/ligerui-all.css" rel="stylesheet" type="text/css" />
<script src="http://www.cnblogs.com/lib/jquery/jquery-1.5.2.min.js" type="text/javascript"></script> 
<script src="http://www.cnblogs.com/lib/ligerUI/js/ligerui.min.js" type="text/javascript"></script>

然后就可以使用liger Grid了

<p id="maingrid"></p> 
<script type="text/javascript"> 
var griddata = [ 
{ id: '01', name: '部门01' }, 
{ id: '02', name: '部门02' }, 
{ id: '03', name: '部门03' }, 
{ id: '04', name: '部门04' }, 
{ id: '05', name: '部门05' }, 
{ id: '06', name: '部门06' }, 
{ id: '07', name: '部门07' } 
]; 
var grid = $("#maingrid").ligerGrid({ 
columns: [ 
{ name: 'id', display: '序号', width: 200 }, 
{ name: 'name', display: '名称', width: 300 } 
], 
data: { Rows: griddata } 
}); 
</script>


效果
数据结构
表格数据结构
表格数据有两个属性,一个是Rows,一个是Total。其中Rows是一个数据数组,Total是记录的总数。
实则是Total在使用本地数据的时候是不需要提供的。我们使用本地数据的格式可以这样:

{ 
Rows: [ 
{ id: '01', name: '部门01' }, 
{ id: '02', name: '部门02' }, 
{ id: '03', name: '部门03' }, 
{ id: '04', name: '部门04' }, 
{ id: '05', name: '部门05' }, 
{ id: '06', name: '部门06' }, 
{ id: '07', name: '部门07' } 
] 
}

id、name都是记录的属性,这里是可以任意自定义的,而在配置columns的时候,并不一定要配置相应的列,只需要配置相应显示的列。在后续的操作中,这些属性都可以取得。比如方法getSelected()。自定义单元格函数render。
树形表格数据结构
树形结构师在表格数据的基础上多了一个children的参数,比如:

{ 
Rows: [ 
{ id: '01', name: '部门01', children: [ 
{ id: '0101', name: '部门0101' }, 
{ id: '0102', name: '部门0102' }, 
{ id: '0103', name: '部门0103' } 
] 
}, 
{ id: '02', name: '部门02' }, 
{ id: '03', name: '部门03' }, 
{ id: '04', name: '部门04' }, 
{ id: '05', name: '部门05' }, 
{ id: '06', name: '部门06' }, 
{ id: '07', name: '部门07' } 
] 
}

两种绑定数据的方式
ligerGrid绑定数据有两种方式,一是使用本地数据,一是使用服务器数据。
在第一个例子中,我们配置了data参数,这种方式是本地方式。另一种方式是配置url参数,使用远程数据。

表格的列提供了很完整的接口可以扩展。无论是内容单元格或者是表头单元格都可以对内容、布局、大小进行自定义。
自定义表头
比如表头,我们可以把display直接设置一段html:

{ 
display: '<a href="javascript:void(0)">部门</a>', //表头列显示的文本,支持html 
name: 'name', 
align: 'left' 
},

或者使用headerRender:

//表头内容自定义函数 
headerRender: function (column) { 
return "<b>" + column.display + "</b>"; 
},


效果图

自定义单元格 column的name是定义单元格链接到 行数据 哪一个属性。比如说上面例子的第一行,把name配置为id,那么显示出来应该就是 "01",如果配置成name,那么显示出来就是 "部门01"。还有align参数,是确定单元格的对齐方式。
如果没有配置render,那么单元格显示的内容将由name确定。

{ name: 'id', display: '序号', width: 200 }, 
{ name: 'name', display: '名称', width: 300 }



上面介绍的是单元格的默认显示方式。除了这种方式,还可以用格式器和自定义函数。
单元格内容的显示规则:
,如果配置了render,使用render
,如果column的type参数扩展了对应的格式化器,那么使用格式化器进行渲染。比如定义了货币格式的格式化器
,最后才是使用默认显示方式
格式化器
通过扩展$.ligerDefaults.Grid.formatters['columntype']来实现,columntype是column配置的type参数。比如现在要格式化一个货币格式的:

$.ligerDefaults.Grid.formatters['currency'] = function (num, column) { 
//num 当前的值 
//column 列信息 
if (!num) return "$0.00"; 
num = num.toString().replace(/$|,/g, ''); 
if (isNaN(num)) 
num = "0.00"; 
sign = (num == (num = Math.abs(num))); 
num = Math.floor(num * 100 + 0.50000000001); 
cents = num % 100; 
num = Math.floor(num / 100).toString(); 
if (cents < 10) 
cents = "0" + cents; 
for (var i = 0; i < Math.floor((num.length - (1 + i)) / 3); i++) 
num = num.substring(0, num.length - (4 * i + 3)) + ',' + 
num.substring(num.length - (4 * i + 3)); 
return "$" + (((sign) ? '' : '-') + '' + num + '.' + cents); 
};


这样只要column的type配置为currency。都会使用这个函数来自定义单元格内容

{ display: '单价', name: 'UnitPrice', align: 'right' ,type:'currency' }

效果图


自定义单元格函数
自定义单元格函数是指配置column的render。我们可以组织任意的html。

var grid = $("#maingrid").ligerGrid({ 
columns: [ 
{ name: 'id', display: '序号', width: 100, 
render: function (record, rowindex, value, column) { 
//this 这里指向grid 
//record 行数据 
//rowindex 行索引 
//value 当前的值,对应record[column.name] 
//column 列信息 
return "<a href='edit.htm?id=" + value + "'>编辑</a>"; 
} 
}, 
{ name: 'id', display: '序号', width: 120, 
render: function (record, rowindex, value, column) { 
return '<input type="button" value="Add"/><input type="button" value="Edit"/><input type="button" value="Delete"/>'; 
} 
}, 
{ name: 'name', display: '名称', width: 300 } 
], 
data: { Rows: griddata } 
});


效果图


单元格编辑器 所有的编辑器的构造的定义在$.ligerDefaults.Grid.editors,比如

editor: { type: 'spinner' }


将会使用$.ligerDefaults.Grid.editors['spinner'] 进行创建编辑器进行构建。
ligerGrid内置提供了 复选框、文本框、日期、数字调整器、下拉框 等编辑器。
效果图

column的参数很多,这里不作一一列举,只介绍了几个常用的参数
更多的可以查看api: http://api.ligerui.com
排序和分页 排序和分页也有两种方式。一种是本地排序和分页。一种是服务器排序和分页。这里只介绍本地的方式。
默认的情况。是启用排序和分页的。如果要取消分页功能,如下:

usePager: false


效果图

事件和方法
事件

事件名参数描述
onAfterAddRow(e)增加行后事件
onAfterBeginEdit(e)开始编辑后事件
onAfterChangeColumnWidth(column, newwidth)改变列宽度事件
onAfterShowData(data)显示完数据事件
onAfterSubmitEdit(e)提交编辑 事件
onBeforeChangeColumnWidth(column, newwidth)验证 改变列宽度 是否通过
onBeforeCheckAllRow(checked, grid element)选择前事件,可以通过return false阻止操作(复选框 全选/全不选)
onBeforeEdit(e)编辑前事件
onBeforeShowData(data)显示数据前事件,可以通过reutrn false阻止操作
onBeforeSubmitEdit(e)验证编辑器结果是否通过
onBeginEdit(e)验证 开始编辑 是否通过
onCancelEdit(e)取消编辑 事件
onChangeSort()改变排序事件
onCheckAllRow(checked, grid element)选择事件(复选框 全选/全不选)
onCheckRow(checked, rowdata, rowindex, rowDomElement)选择事件(复选框)
onContextmenu(parm, e)右击事件
onDblClickRow(rowdata, rowindex, rowDomElement)双击行事件
onDragCol(node)拖动列事件
onError()错误事件
onLoaded()加载完函数
onLoading()加载时函数
onReload()刷新事件,可以通过return false来阻止操作
onSelectRow(rowdata, rowindex, rowDomElement)选择行事件
onSubmit()提交前事件
onSuccess()成功事件
onToFirst()第一页,可以通过return false来阻止操作
onToggleCol()切换列事件
onToLast()最后一页,可以通过return false来阻止操作
onToNext()下一页,可以通过return false来阻止操作
onToPrev()上一页,可以通过return false来阻止操作
onUnSelectRow(rowdata, rowindex, rowDomElement)取消选择行事件

例子

var grid = $("#maingrid").ligerGrid({ 
columns: [ 
{ name: 'id', display: '序号', width: 200 }, 
{ name: 'name', display: '名称', width: 300 } 
], 
data: { Rows: griddata }, 
onSelectRow: function (rowdata, rowindex) { 
//行记录 对于数据行 
//行索引 第几行,从0开始 
alert(rowdata.name); 
} 
}); 
grid.bind('SelectRow', function (rowdata, rowindex) { 
//this 这里的this都是指向grid 
//行记录 对于数据行 
//行索引 第几行,从0开始 
alert(rowdata.name); 
});


方法

方法参数描述
addEditRow(rowdata)
  • 增加一个编辑行

  • addRow(rowdata, rowParm, isBefore, parentRow)
  • 增加新行

  • addRows(rowdataArr)
  • 一次性增加多行

  • appendRow(rowData, targetRow, nearRow, isBefore)
  • 附加新行(树模式)

  • beginEdit(rowParm)
  • 进入编辑状态

  • cancelEdit(rowParm)
  • 取消编辑

  • changeHeaderText(columnparm, headerText)
  • 改变表头文本

  • changePage(ctype)
  • 改变分页

  • changeSort(columnName, sortOrder)
  • 改变排序

  • collapse(targetRow)
  • 收缩(树模式)

  • collapseDetail(rowParm)
  • 收缩明细

  • deleteRow(rowParm)
  • 选择行

  • deleteSelectedRow()
  • 删除选择的行

  • demotion(targetRow)
  • 降级(树模式)

  • endEdit(rowParm)
  • 结束编辑

  • expand(targetRow)
  • 展开(树模式)

  • extendDetail(rowParm)
  • 展开明细

  • formatRecord(record)
  • 格式化数据,删除系统字段

  • getAdded()
  • 获取新增的数据

  • getCheckedRowObjs()
  • 获取选中的行 DOM对象集合

  • getCheckedRows()
  • 获取选中的行数据(复选框)

  • getChidren(rowParm)
  • 获取子节点数据(树模式)

  • getColumn(columnpam)
  • 获取列信息

  • getColumns(columnLevel)
  • 获取指定层级的Columns

  • getColumnType(columnname)
  • 根据列名获取列类型

  • getData(status, removeStatus)
  • 获取数据

  • getDeleted()
  • 获取删除过的数据

  • getParent(rowParm)
  • 获取父节点数据(树模式)

  • getRowObj(rowParm)
  • 行DOM转换为行数据

  • getSelected()
  • 获取选中的行数据(同getSelectedRow)

  • getSelectedRow()
  • 获取选中的行数据

  • getSelectedRowObj()
  • 获取选中的行 DOM对象

  • getSelectedRowObjs()
  • 获取选中的行 DOM对象集合

  • getSelectedRows()
  • 获取选中的行数据集合(支持Ctrl多选)

  • getSelecteds()
  • 获取选中的行数据集合(支持Ctrl多选)(同getSelectedRows)

  • getUpdated()
  • 获取修改过的数据

  • hasChildren(rowParm)
  • 是否包括子节点(树模式)

  • isLeaf(rowParm)
  • 是否叶节点(树模式)

  • isTotalSummary()
  • 是否包含汇总

  • loadData(loadDataParm)
  • 刷新数据

  • loadServerData(param, clause)
  • 加载数据(服务器)

  • reRender(e)
  • 重新加载html

  • setColumnWidth(columnparm, value)
  • 调整列宽

  • setOptions(parms)
  • 重新设置参数(同名方法set)

  • SubmitEdit(rowParm)
  • 提交编辑

  • toggle(targetRow)
  • 伸展/收缩节点(树模式)

  • toggleCol(columnparm, visible)
  • 显示/隐藏列

  • updateCell(cell, value, rowParm)
  • 更新单元格

  • updateRow(newRowData, rowDom)
  • 更新行

  • upgrade(targetRow)
  • 升级(树模式)

  • 例子

    <a class="l-button" href="javascript:selectRow(2)">选择行(3)</a> 
    <a class="l-button" href="javascript:getSelectRow()">获取选择</a>
    var grid = $("#maingrid").ligerGrid({ 
    columns: [ 
    { name: 'id', display: '序号', width: 200 }, 
    { name: 'name', display: '名称', width: 300 } 
    ] 
    }); 
    grid.set({ data: { Rows: griddata} }); 
    function selectRow(index) { 
    grid.select(index); 
    } 
    function getSelectRow() { 
    var rows = grid.getSelecteds(); 
    for (var i in rows) { 
    alert(rows[i].name); 
    } 
    }

    相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

    推荐阅读:

    jQuery操作表格的插件datatables如何应用

    jQuery做出玻璃质感手风琴特效步骤详解(附代码)

    热心网友 时间:2022-04-23 04:39

    入jQuery库和ligerui的引用 四:模板页增加视图的链接 准备数据结构(ligerGrid的调用... 可以查看到grid加载分页数据的时候,会往服务器传几个数据: 那么在后台我们需要根据... { Rows = targetList, Total = total }追问菜鸟 能否详细讲解下?

    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    水笔在手上画画会不会被衣服搽掉下来 老人每天大便次数很多量不多也不稀,每天还会拉三四次水应经三个月了... 从大连飞机场怎么去大连经济开发区5彩城K区的大连金港大酒店 除了打 ... 请问从大连周水子国际机场到经济技术开发区怎么走最省钱? 中国古代名刀总录中国古代十大名刀 怎样把qq安装到iphone里面 苏科大什么梗 苏科大叫什么名字 lol苏科大是苏州科技大学的吗 lol苏州科技大学为什么这么厉害 优尔精医用降温贴是不是保健品? b站保护我方药水哥什么梗 网红药水哥公布恋情,网友直呼房子塌了,药水哥不配有女朋友吗? 药水哥再发说唱新曲,这首歌为什么得到很多网友的力挺? 求《唐顿庄园》的片头曲MP3.yochundaisy@163.com 唐顿庄园不知道是哪一集,帕特莫尔太太为了糊弄Daisy,拿一块木板在字母表上移来移去,说是什么很灵 唐顿庄园 daisy 看美国电影 哪一集 哪部美剧里有叫daisy的 唐顿庄园哪一集 daisy 把各屋女仆叫醒 唐顿庄园 第二季vera是怎么知道mary的丑闻的?详细点。 看唐顿庄园一直不明白 贝茨为什么说托马斯是小人? j2ee项目 ssh+jquery ligerui 框架,使用ligerui的表格,根据条件查询,使用obj(表格对象).loadServerData 求问三相变压器的零序电抗是如何计算出来的 大接地系统单相接地时,为什么零序电流等于故障点电流 零序电流保护计算方法 请问零序电流怎么计算? 下载了大富翁6,可是游戏里面是乱码,怎么解决 刚在浏览器下载的快吧游戏,下载完怎么是乱码……一打开就显示违法软件正在安装和图片上的东西 下载游戏文件乱码无法实用怎么办 股票半仓卖出去的盈利在哪里 我手机下载游戏怎么字都是乱码啊! 学生开学上海交警提醒了哪些事? 如何将搜狗拼音输入法词序还原 搜狗输入法 调整词序 搜狗拼音输入法中如何固定词序? 手机如何设置wifi密码 雅安到敦煌莫高窟多少公里 国内航班化妆品托运有限制吗?香水可以带吗? 电池效率为什么掉的那么快? 手机关了陌生号码静音,如何打开 小米8接打不了电话然后流量开了用不了,但是信号满格是什么问题 小米8有时候突然就wifi连上自动关,手机卡不好使,流量不让开,然后过一会就自动重启,什么原因? 木瓜浸鸡的做法窍门 台湾红心木瓜,青皮可以直接吃么 12电池效率,刚掉了百分之一,两天又掉百分之一咋回事 小米note3选用那款内置配置的无线充电模块 小米2可以无线充电吗? CAD2000命令栏不见啦。怎么弄 CAD2000版的命令窗口不小心关掉了、按ctrl也没用用、要怎么做才能调出来... 同一个人的手机号和qq号分别能申请两个吗? 一个qq可以绑定几个?