JQuery EasyUI中datagrid的使用
在学习过程中,可以参照JQuery EasyUI的官方网站学习。地址:http://www.jeasyui.com/demo/main/index.php
在学习JQuery EasyUI中的DataGrid标签时,可以参照http://www.jeasyui.com/documentation/datagrid.php进行学习。
本文主要讲解DataGrid标签的使用,怎么设置参数,怎么向后台请求数据等。
在使用过程中,我使用的是1.4版本,存在一个问题,当请求数据为0行时,会重新请求一次。
这一个问题,园中兄弟帮我解决了,地址是:http://www.cnblogs.com/Reaver/p/4056770.html,感谢flyreaver
一、在页面中添加标签
@*这是datagrid标签展示的地方,其中iconcls表示datagrid中左上角展示的图标*@
<table id="dg" iconcls="icon-edit">
</table>
@*如果需要弹出层,请参照下边的代码,并在js中做相应的设置*@
<div id="dlg" class="easyui-dialog" title="弹出框标题" style="width: 400px; height: 200px; padding: 10px"
data-options="
iconCls: 'icon-add',
buttons: [{
text:'确定',
iconCls:'icon-ok',
handler:function(){
//点击'确定'按钮触发的事件
UpdateData();
}
},{
text:'取消',
handler:function(){
alert('cancel');;
}
}]
">
<div class="aaa">
<span>主键id:</span><input type="text" />
</div>
</div>
二、在js中添加方法,如下所示:
<script type="text/javascript">
$(function () {
loadData();
}); function loadData() {
$('#dg').datagrid({
url: '/Financial/GetLoanDataInfo',//请求方法的地址
title: '信息管理',
width: 900,
height: 400,
fitColumns: true, //列自适应
nowrap: false,//禁止文字自动换行
idField: 'CID',//主键列的列明
loadMsg: '正在加载信息...',//当数据没有加载出来时显示的文字
pagination: true,//是否有分页
singleSelect: true,//是否单行选择
pagePosition: 'bottom',//分页符在底部,可选参数为top,bottom,both
pageSize: 15,//页大小,一页多少条数据
pageNumber: 1,//默认当前的页码
pageList: [15, 30, 50],//一页可显示数据的条目
queryParams: {},//往后台传递参数,json格式
columns: [[
//field表示绑定的字段名,如不绑定就随便写一个;
//checkbox: true表示这一列是checkbox
//hidden: true表示隐藏这一列
//sortable: true表示单击这一列可以排(升/降)序,这样请求数据时会向后台多传输两个参数
{ field: 'ck', checkbox: true, align: 'left', width: 50 },
{ field: 'CID', title: '1', width: 80, align: 'center', hidden: true },
{ field: 'CMoney', title: '2', width: 80, align: 'center', sortable: true },
{
field: 'CAge', title: '3', width: 80, align: 'center',
//这里表示对显示的信息做处理。value表示原本的值,在方法中对value进行逻辑判断并返回处理后的标签样式
formatter: function (value, row, index) {
//在该函数中,对文本大小判断,如果大于18,显示为红色的字
if (value > 18) {
return '<span style="color:red;">' + value + '</span>';
} else {
return value;
}
}
},
{
field: 'CTitle', title: '7', width: 80, align: 'center',
formatter: function (value, row, index) {
//在该函数中,把这一列变为一个a标签。设置class和自定义数据。为下边做准备
return "<a href='javascript:void(0);' data-id='" + row.CID + "' class='detailLink'>" + value + "</a>";
}
}
]],
//绑定数据成功后执行这个方法
onLoadSuccess: function () {
//先把弹出框关闭
$('#dlg').dialog('close');
//添加最后一列的单击事件
$('.detailLink').click(function () {
//获取自定义数据
var id = $(this).data('id');
//为弹出的层中的标签赋值
$('.aaa input').attr('value', id);
//弹出层
$('#dlg').dialog('open');
});
}
});
}
function UpdateData() {
//点击弹出层的确定按钮触发的事件——刷新datagrid
$('#dg').datagrid('reload');
};
</script>
三、后端得到datagrid传过去的参数,并返回数据
//在本系统中,datagrid请求的方法需要是Action类型的方法
public ActionResult GetLoanDataInfo()
{
int pageIndex;
int pageSize;
string sortName = string.Empty;
string order = string.Empty;
//page是datagrid内部实现的,传过来的参数名。表示第几页
if (!int.TryParse(Request.Form["page"], out pageIndex))
{
pageIndex = ;
}
//rows表示这一页显示多少条数据
if (!int.TryParse(Request.Form["rows"], out pageSize))
{
pageSize = ;
}
//sort表示根据那一列排序;order表示升序或者降序,有两个值:asc、desc
if (!string.IsNullOrEmpty(Request.Form["sort"]))
{
sortName = Request.Form["sort"];
order = Request.Form["order"];
}
//这一块是从后台请求数据,把上边的参数传进去(本例是模拟的,没有传参数进方法,应该在方法中同时把总数据的条目数out出来)
List<TLoan> list = _DataHelper.GetData();
int totalCount = list.Count();
list = list.Skip((pageIndex - ) * pageSize).Take(pageSize).ToList();
//把需要传给前台的数据,分拣出来,赋给rows,这样可以把不需要的数据过滤掉,如果不用过滤数据,可以省略下边一行代码
var rows = from l in list
select new { CID = l.CID, CMoney= l.CMoney, CAge= l.CAge, CTitle= l.CTitle };
31
//rows = rows, total = totalCount;等号之前的名字是不可变的,因为是easy ui规定的。
//JsonRequestBehavior.AllowGet表示该方法可以被get方式请求,否则get方式请求得不到数据
return Json(new { rows = rows, total = totalCount }, JsonRequestBehavior.AllowGet);
}
JQuery EasyUI中datagrid的使用的更多相关文章
- JQuery EasyUI的datagrid的使用方式总结
JQuery EasyUI的datagrid的使用方式总结第一步:添加样式和js脚本在前台添加展示数据表格的table元素 例如: <div> <table id="tt& ...
- 给Jquery easyui 的datagrid 每行增加操作链接(转)
http://www.thinkphp.cn/code/207.html 通过formatter方法给Jquery easyui 的datagrid 每行增加操作链接我们都知道Jquery的EasyU ...
- 第二百二十二节,jQuery EasyUI,DataGrid(数据表格)组件
jQuery EasyUI,DataGrid(数据表格)组件 学习要点: 1.加载方式 2.分页功能 本节课重点了解 EasyUI 中 DataGrid(数据表格)组件的使用方法,这个组件依赖于 Pa ...
- EasyUI 中 DataGrid 控件 列 如何绑定对象中的属性
EasyUI 中 DataGrid 控件 是我们经常用到的控件之一, 但是 DataGrid 控件 在绑定显示列时却不支持对象属性绑定. 模型如下: public class Manager impl ...
- Jquery EasyUI中treegrid
Jquery EasyUI中treegrid的中右键菜单和一般按钮同时绑定事件时的怪异事件 InChatter系统开源聊天模块前奏曲 最近在研究WCF,又因为工作中的项目需要,要为现有的系统增加一 ...
- EasyUI中datagrid的基本用法
EasyUI中datagrid是最常用的一个控件了,现在整理一下datagrid的基本语法,先展示下页面效果吧,如下图
- jquery easyUI中combobox的使用总结
jquery easyUI中combobox的使用总结 一.如何让jquery-easyui的combobox像select那样不可编辑?为combobox添加editable属性 设置为false ...
- 求助关于jquery easyUI中的treegrid组件,请各位帮忙给个思路,谢谢啦
现在项目中用到jquery easyUI中的treegrid组件,已经可以正常显示了.但是在保存的时候遇到问题,页面上参照官网的例子可以在页面更新,但是怎么获取编辑后的数据进而保存到数据库呢?
- EasyUI中datagrid双击事件
EasyUI中datagrid双击事件 在jsp文件底部增加代码: <script type="text/javascript"> //数据表双击事件 $('#tabl ...
随机推荐
- Android 学习笔记多媒体技术之 AsyncTask+实现音频播放...
PS:今天搞了一下如何实现音频播放...结果被坑了,看书上写的代码是挺简单的,但是有个函数就是死活没看懂,这真是受不了...最后才弄明白,原来是一个实现异步任务的一个类...这个类使用java.uti ...
- Android的init过程(二):初始化语言(init.rc)解析
Android的init过程(一) 本文使用的软件版本 Android:4.2.2 Linux内核:3.1.10 在上一篇文章中介绍了init的初始化第一阶段,也就是处理各种属性.在本文将会详细分析i ...
- java.lang.IllegalArgumentException 不合法的参数异常
报错内容: IllegalArgumentException 不合法的参数异常 十二月 06, 2016 10:06:56 上午 org.apache.catalina.core.StandardWr ...
- ACM中的浮点数精度处理
在ACM中,精度问题非常常见.其中计算几何头疼的地方一般在于代码量大和精度问题,代码量问题只要平时注意积累模板一般就不成问题了.精度问题则不好说,有时候一个精度问题就可能成为一道题的瓶颈,让你debu ...
- MVC应用程序中管理(更新)上传的文件
实现上传文件功能,有时上传也会操作出错,能让用户有改正有机会,开发上传文件能有更新的功能. 文件上传时,如果是存储于应用程序某一目录的话,在更新时需要了解一些流程,先是删除旧文件,更新数据表相关信息, ...
- Ext.NET 4.1 最新版本破解
Ext.NET 4.1 最新版本破解 今天在将Ext.NET 4.1版本的程序发布到公网时居然要license(localhost和127.0.0.1不收费),而且一年$4999,突然间觉得这是什么鬼 ...
- python代码风格-PEP8
转载自http://www.douban.com/note/134971609/ Python 的代码风格由 PEP 8 描述.这个文档描述了 Python 编程风格的方方面面.在遵守这个文档的条件下 ...
- 如何把maven项目转成web项目
创建Web工程,使用eclipse ee创建maven web工程 1.右键项目,选择Project Facets,点击Convert to faceted from 2.更改Dynamic Web ...
- task mysqld:26208 blocked for more than 120 seconds
早上10点左右,某台线上ECS服务器突然没响应. 查看日志,发现如下信息: Aug 14 03:26:01 localhost rsyslogd: [origin software="rsy ...
- JSON的三种解析方式
一.什么是JSON? JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度. JSON就是一串字符串 只不过元素会使用特定 ...