jquery的前端框架挺多的,有easyUI ,bootstrap...,对于做系统软件或许easyUI比较好,因为里面控件很丰富,而bootstrap非常简洁大方,但是控件相
对比较少,特别是复杂的网格控件,几乎要自己来写!

介绍一下的easyUI 的datagrid,感觉写法还是比较简单易懂,重用性比较强!
主要实现了显示数据,查询数据(序列化传参),datagrid分页样式选用。

页面如下:

例子依赖:
1、asp.net mvc
2、easyui文件依赖包
    下载地址:http://www.jeasyui.com/download/index.php
3、jquery.serialize-object.js
    下载地址:https://github.com/macek/jquery-serialize-object

后端代码:
1、依赖的类:
    1)Pager 兼容EasyUi 分页(用于查询条件实体继承)

     /// <summary>
/// 兼容EasyUi 分页(用于查询条件实体继承)
/// </summary>
public class Pager
{
/// <summary>
/// 兼容EasyUi 分页参数,当前页
/// </summary>
public Int32 Page { get; set; } /// <summary>
/// 兼容EasyUi 分页参数,每页记录数
/// </summary>
public Int32 Rows { get; set; }
}

2)PersonConditions 查询条件实体类,继承Pager

     /// <summary>
/// 查询条件实体类
/// </summary>
public class PersonConditions:Pager
{
public String Code { get; set; }
public String Name { get; set; }
public String Sex { get; set; }
public String Addr { get; set; }
public String Phone { get; set; }
public Double? Price { get; set; }
}

3)Person Person实体

     /// <summary>
/// Person实体
/// </summary>
public class Person
{
public String Code { get; set; }
public String Name { get; set; }
public String Sex { get; set; }
public String Addr { get; set; }
public String Phone { get; set; }
public Double? Price { get; set; }
}

4)DataGridObj 兼容EasyUi DataGrid分页数据结构

     /// <summary>
/// 兼容EasyUi DataGrid分页数据结构
/// </summary>
public class DataGridObj
{
/// <summary>
/// 总数量
/// </summary>
public Int32 total { get; set; } /// <summary>
/// 数据
/// </summary>
public Object rows { get; set; }
}

2、Home控制器
    1)Index() 加载页面的方法
    2)GetJson() DataGrid 获取数据的方法

     public class HomeController : Controller
{
public ActionResult Index()
{
return View();
} [HttpPost]
public JsonResult GetJson(PersonConditions personWhere)
{
DataGridObj dgObj = new DataGridObj(); #region 产生List<Person>数据
List<Person> list = new List<Person>();
for (int i = ; i < ; i++)
{
Person person = new Person()
{
Code = "code" + i.ToString(),
Name = "name" + i.ToString(),
Sex=i%==?"男":"女",
Addr="Addr"+i.ToString(),
Phone=""+i.ToString(),
Price = i
}; list.Add(person);
}
#endregion IQueryable<Person> iqPerson = list.AsQueryable();
#region 查询条件
if (String.IsNullOrEmpty(personWhere.Code) == false)
iqPerson = iqPerson.Where(a => a.Code == personWhere.Code);
if (String.IsNullOrEmpty(personWhere.Name) == false)
iqPerson = iqPerson.Where(a => a.Name == personWhere.Name);
if (personWhere.Price != null)
iqPerson = iqPerson.Where(a => a.Price == personWhere.Price);
#endregion list = iqPerson.ToList();
dgObj.rows = list.Skip((personWhere.Page - ) * personWhere.Rows).Take(personWhere.Rows);
dgObj.total = list.Count();
return Json(dgObj, JsonRequestBehavior.AllowGet);
}
}

前端代码:
1、脚本
    1)Common:通用类
         SerializeObject:序列化form为对象
    2)EasyUIHelper: EasyUI的帮助类
         InitTextBox:设置textbox共同的初始属性,统一风格
         InitDgPagination:设置datagrid的分页样式(放在datagrid初始化后),dgId为datagrid的id
    3)myDgObj:进行对本页面datagrid的初始化,各种方法定义、调用
    4)$(function () { });别忘了在里面调用初始化控件方法
2、HTML
    1)form 查询条件
    2)id为dg的div为用于绑定datagrid

3、页面代码

 @{
Layout = null;
}
<link rel="stylesheet" type="text/css" href="~/easyui/themes/default/easyui.css">
<link rel="stylesheet" type="text/css" href="~/easyui/themes/icon.css"> <script type="text/javascript" src="~/easyui/jquery.min.js"></script>
<script type="text/javascript" src="~/easyui/jquery.easyui.min.js"></script>
<script type="text/javascript" src="~/Scripts/jquery.serialize-object.min.js"></script>
<style>
body {font-family: "Microsoft YaHei",sans-serif;}
.from_box {padding: 10px 10px 0px 0px;overflow: hidden;}
.from_box .item {width:280px;float:left; margin:5px;}
.from_box .item label:first-child { width:85px;text-align:right;display:inline-block;}
.from_box .item input{ padding-left:5px;}
/*.from_box .item_row {width:100%;float:left; margin:5px;display:inline-block;}
.from_box .item_row label:first-child { width:85px;text-align:right;display:inline-block;}
*/ </style>
<form class="from_box">
<div class="item"><label>编码编码:</label><input name="Code" class="easyui-textbox" data-options="iconCls:'icon-man'" /></div>
<div class="item"><label>Name:</label><input name="Name" class="easyui-textbox" /></div>
<div class="item"><label>Sex:</label><input name="Sex" class="easyui-textbox" /></div>
<div class="item"><label>Addr:</label><input name="Addr" class="easyui-textbox" /></div>
<div class="item"><label>Phone:</label><input name="Phone" class="easyui-textbox" /></div>
<div class="item"><label>Price:</label><input name="Price" class="easyui-textbox" /></div>
</form> <div id="dg"></div>
<script> /*通用类*/
var Common = {
SerializeObject: function (fromClass) { /*序列化成对象,fromClass为html元素为form的class,默认为.from_box*/
if (fromClass == null)
fromClass = ".from_box";
return $(fromClass).serializeObject();
}
} /*EasyUI的帮助类*/
var EasyUIHelper = {
/****************** textbox的帮助方法 Begin ********************/
InitTextBox: function () { /*设置textbox的初始属性,统一风格*/
var tbOptions = $(".item .easyui-textbox").textbox({
height: 30,
width: 190
});
},
/****************** textbox的帮助方法 End **********************/ /****************** datagrid的帮助方法 Begin ******************/
InitDgPagination: function (dgId) { /*设置datagrid的分页样式(放在datagrid初始化后),dgId为datagrid的id*/
$(dgId).datagrid("getPager").pagination({
layout: ["list", "sep", "first", "prev", "links", "next", "last", "sep", "refresh"],
displayMsg: "显示 {from} 到 {to} 共 {total} 项"
});
}
/****************** datagrid的帮助方法 End ********************/
} var myDgObj = {
Search: function () {
$("#dg").datagrid("load", Common.SerializeObject());
},
Edit: function () {
alert("edit");
},
Load: function () {
$("#dg").datagrid("load", Common.SerializeObject());
},
InitDataGrid: function () {
$("#dg").datagrid({
url: '@Url.Action("GetJson", "Home")',
method: "post",
pagination: "true",
rownumbers: "true",
fitColumns: "true",
singleSelect: "true",
frozenColumns: [[
{ field: "Code", title: "Code", width: 100 },
{ field: "Name", title: "Name" }
]],
columns: [[
{ field: "Sex", title: "Sex" },
{ field: "Addr", title: "Addr" },
{ field: "Phone", title: "Phone" },
{ field: "Price", title: "Price", align: "right" }
]],
toolbar: [
{ text: "查询", iconCls: "icon-search", handler: "myDgObj.Search" }, '-',
{ text: "编辑", iconCls: "icon-edit", handler: "myDgObj.Edit" }
]
}); EasyUIHelper.InitDgPagination("#dg"); //datagrid初始化同时,初始页脚(分页)样式
}
} $(function () {
EasyUIHelper.InitTextBox(); //easyui-textbox统一初始化属性
myDgObj.InitDataGrid(); //datagrid初始化
});
</script>

注意:
     $("#dg").datagrid("load", Common.SerializeObject());
查询时,通过序列化form为对象post到GetJson()作为入参

EasyUI datagrid简单运用的更多相关文章

  1. easyUI datagrid editor扩展dialog

    easyUI datagrid简单使用:着重两点1.editor对象的click事件:2.将dialog窗体内的值填写到当前正编辑的单元格内 <!DOCTYPE html> <htm ...

  2. easyUI datagrid笔记

    easyUI datagrid 简单使用与注意细节 背景: 业余爱好,使用了一下easyUI的搜索框与数据表格,并把两者整合起来进行使用. 使用前提(引入需要的js and css): <lin ...

  3. EasyUI Datagrid的简单使用

    此前同样写过EasyUI Datagrid的demo,好记性不如烂笔头,何况记性也不是那么好,赶紧记录一下.照搬上一篇EasyUI Tree的格式. 实现效果:获取数据库表的数据,在EasyUI Da ...

  4. easyui datagrid中 多表头方法总结

    easyui datagrid中怎么设置表头成多行显示呢?其实很简单,就是给datagrid的columns属性设置成多个数组就行了.下面直接看例子吧,这是一个两行表头的,按照此方法,还可以设置三行表 ...

  5. EasyUI DataGrid分页数据绑定

    记录东西感觉很痛苦,总结东西很痛苦,麻烦,不过为了下次的方便和知识的牢固以后要坚持总结. EasyUI DataGrid分页数据绑定 在解决方案中新建两个文件FormMain.aspx(html也可以 ...

  6. [转载]再次谈谈easyui datagrid 的数据加载

    这篇文章只谈jQuery easyui datagrid 的数据加载,因为这也是大家谈论最多的内容.其实easyui datagrid加载数据只有两种方式:一种是ajax加载目标url返回的json数 ...

  7. Easyui Datagrid rownumbers行号四位、五位显示不完全的解决办法

    Easyui Datagrid rownumbers行号四位.五位显示不完全的解决办法(引) 方法一: 相信很多人在使用easyui的时候都遇到过这个问题,当我们设置成显示Rownumber的时候,你 ...

  8. 反射实体自动生成EasyUi DataGrid模板 第二版--附项目源码

    之前写过一篇文章,地址 http://www.cnblogs.com/Bond/p/3469798.html   大概说了下怎么通过反射来自动生成对应EasyUi datagrid的模板,然后贴了很多 ...

  9. 解决easyui datagrid加载数据时,checkbox列没有根据checkbox的值来确定是否选中

    背景:   昨天帮朋友做一个easyui datagrid的小实例时,才发现easyui datagrid的checkbox列,没有根据值为true或false来选中checkbox,当时感觉太让人失 ...

随机推荐

  1. Android 中HttpURLConnection与HttpClient的简单使用

    1:HttpHelper.java public class HttpHelper { //1:标准的Java接口 public static String getStringFromNet1(Str ...

  2. 装饰者模式 (decorator pattern)

    参考 : Head First 设计模式(中文版) 这篇只作为个人温习! 用意 : 动态地给一个对象添加|扩展一些行为.Decorator 强调用对象组合而非继承来实现扩展,这显得较为灵活. 角色: ...

  3. ngRoute 路由

    做单页面应用多是通过不同的url来识别出不同的页面展现的. angularjs 为我们提供一个封装好的ngRoute工具 简单介绍用法 : <div ng-view></div> ...

  4. Altium Designer 09 (Protel)总线使用方法(解决导入PCB无网络标号问题)

    弄了两天的Protel总线问题终于解决了,一开始顶层总线连接好后,导入PCB没有网络标号,也就是两个子图信号没连上.现在将正确的连接和设置方法公布如下: 1.首先画好子图的总线,如下图所示.注意:中括 ...

  5. rsyslog 日志服务器接收日志权限问题

    rsyslog 权限: 默认 [root@dr-mysql01 zjzc_log]# ls -ltr zj-frontend0*-access*27 -rw------- 1 root root 32 ...

  6. VS快捷键大全(转)

    相信.Net开发人员都想能够熟记各种VS快捷键以提高平时开发的效率,但苦于记忆能力太差而快捷键又特别多,特别烦,所以作罢! 下面我将简单介绍一下我记忆VS快捷键的一些方法,希望对大家有所帮助. 1.窗 ...

  7. String和数字之间的转化

    主要是JDK的代码,还是比较的经典,值得一看,例如: package alg; /** * @author zha 字符串之间的转化 */ public class Alg3StringToint { ...

  8. 简单的新闻客户端APP开发(DCloud+thinkphp+scrapy)

    前端时间花了1个月左右,搞了个新闻APP,功能很简单,就是把页面版的新闻条目定时爬到后台数据库,然后用app显示出来. 1.客户端 使用了DCloud框架,js基本是个新手,从没写过像样的代码,htm ...

  9. EditText设置可以编辑和不可编辑状态

    1.首先想到在xml中设置android:editable="false",但是如果想在代码中动态设置可编辑状态,没有找到对应的函数 2.然后尝试使用editText.setFoc ...

  10. sql server里一些常用的查询

    查看表的创建和更改时间:  select * from sys.tables    查询数据库的创建时间: select * from sys.databases where name in ('数据 ...