EasyUI后台管理系统学习三

接连折腾了1天,通过不断的学习和调试,今天终于搞定了easyui中的重要一环——datagrid的数据绑定。

1天的折腾算不了什么,其实只是给我加深了对easyui框架的理解罢了,通过不断的学习easyui的中文指南,让我明白了datagrid数据绑定的写法和用法,也下载了相关的demo捣鼓了一阵,但是在iis7.5 和vs2010下的应用程序却始终没有能够成功,为什么在普通html页面能够正常显示的datagrid的代码在这个里面(我新建了一个aspx页面)却始终搞不定呢?接下来我走上了网络搜索和easyui中文指南详细研究之路(有针对性的是datagrid)。在不断的阅读和实践后,终于是看到了一点曙光,以下就从失败和正确2个方面来写学习的一点点东西:

1、环境:vs2010  IIS7.5

2、引用框架:jquery-1.7.2.min.js、jquery.easyui.min.js、easyui-lang-zh_CN.js、easyui.css、icon.css

3、本地json文件:datajson.json

  

  内容:{
 "total":20,
 "rows":[
 {"productid":"FI-SW-01","productname":"Koi","unitcost":"10.00","status":"P","listprice":"36.50","attr1":"Large","itemid":"EST-1"},
 {"productid":"FI-SW-01","productname":"Koi","unitcost":"10.00","status":"P","listprice":"36.50","attr1":"Large","itemid":"EST-1"},
 {"productid":"FI-SW-01","productname":"Koi","unitcost":"10.00","status":"P","listprice":"36.50","attr1":"Large","itemid":"EST-1"},
 {"productid":"FI-SW-01","productname":"Koi","unitcost":"10.00","status":"P","listprice":"36.50","attr1":"Large","itemid":"EST-1"},
 {"productid":"FI-SW-01","productname":"Koi","unitcost":"10.00","status":"P","listprice":"36.50","attr1":"Large","itemid":"EST-1"},
 {"productid":"FI-SW-01","productname":"Koi","unitcost":"10.00","status":"P","listprice":"36.50","attr1":"Large","itemid":"EST-1"}
]}

以上是基本条件,接下来我写了几种错误的前台代码,这个代码始终是显示不出来的:

1.<table class="easyui-datagrid" title="基本数据表格" style="width:700px;height:250px"
        data-options="singleSelect:true,collapsible:true,url:‘datajson.json‘" id="table1">
    </table>

这个是直接在内部定义

2.<table class="easyui-datagrid" title="基本数据表格" style="width:700px;height:250px"
        data-options="singleSelect:true,collapsible:true" id="tb">
    </table>

<script type="text/javascript">

$(function () {

  $("#tb").datagrid({

    url: "datajson.json",

    method: "post",

    fitColumns:true,

    columns: [[

    { field: "ck", checkbox: true },

    { field: "itemid", title: "itemid", width: 100 },

    { field: "listprice", title: "listprice", width: 100 },

    { field: "unitcost", title: "unitcost", width: 100 },

    { field: "attr1", title: "attr1", width: 100 },

    { field: "status", title: "status", width: 100 },

    { field: "productid", title: "productid", width: 100 },

]],

    pagination: true,

    onLoadSuccess: function () { alert(‘success‘); },

    onLoadError: function () { alert(‘error‘); }

  });

});

</script>

这个是通过JS定义,唯一不同的是method,由get变成了post,显示不出来,

3.这个是在那个demo 中看到的写法:

<table class="easyui-datagrid" title="列表数据" style="width:700px;height:250px"
   data-options="singleSelect:true,collapsible:true,url:‘datajson.json‘,method:‘get‘">
  <thead>
   <tr>
    <th data-options="field:‘itemid‘,width:80">Item ID</th>
    <th data-options="field:‘productid‘,width:100">Product</th>
    <th data-options="field:‘listprice‘,width:80,align:‘right‘">List Price</th>
    <th data-options="field:‘unitcost‘,width:80,align:‘right‘">Unit Cost</th>
    <th data-options="field:‘attr1‘,width:250">Attribute</th>
    <th data-options="field:‘status‘,width:60,align:‘center‘">Status</th>
   </tr>
  </thead>
 </table>

上面3种都搞不定,我写下了正确的:

.<table class="easyui-datagrid" title="基本数据表格" style="width:700px;height:250px"         data-options="singleSelect:true,collapsible:true" id="tb">     </table>

<script type="text/javascript">

$(function () {

  $("#tb").datagrid({

    url: "datajson.json",

    method: "get",

    fitColumns:true,

    columns: [[

    { field: "ck", checkbox: true },

    { field: "itemid", title: "itemid", width: 100 },

    { field: "listprice", title: "listprice", width: 100 },

    { field: "unitcost", title: "unitcost", width: 100 },

    { field: "attr1", title: "attr1", width: 100 },

    { field: "status", title: "status", width: 100 },

    { field: "productid", title: "productid", width: 100 },

]],

    pagination: true,

    onLoadSuccess: function () { alert(‘success‘); },

    onLoadError: function () { alert(‘error‘); }

  });

});

</script>

就是这样,不解释了。具体还有更加详细的关于datagrid的定义的项还有很多,我是在指南和网上看到的,下面我转一个文章来自网络,很详细的解释:

jQuery EasyUI API 中文文档 - DataGrid数据表格使用说明,需要的朋友可以参考下。

扩展自 $.fn.panel.defaults ,用 $.fn.datagrid.defaults 重写了 defaults 。 依赖
panel resizable linkbutton pagination 用法

复制代码 代码如下:

<table id="tt"></table>

复制代码 代码如下:

$(‘#tt‘).datagrid({
url:‘datagrid_data.json‘, columns:[[
{field:‘code‘,title:‘Code‘,width:100},
{field:‘name‘,title:‘Name‘,width:100},
{field:‘price‘,title:‘Price‘,width:100,align:‘right‘} ]] });

数据表格(DataGrid)的特性

其特性扩展自 panel,下列是为 datagrid 增加的特性。


名称


类型


说明


默认值


columns


array


datagrid 的 column 的配置对象,更多详细请参见 column 的特性。


null


frozenColumns


array


和列的特性一样,但是这些列将被冻结在左边。


null


fitColumns


boolean


True 就会自动扩大或缩小列的尺寸以适应表格的宽度并且防止水平滚动。


false


striped


boolean


True 就把行条纹化。(即奇偶行使用不同背景色)


false


method


string


请求远程数据的 method 类型。


post


nowrap


boolean


True 就会把数据显示在一行里。


true


idField


string


标识字段。


null


url


string


从远程站点请求数据的 URL。


null


loadMsg


string


当从远程站点加载数据时,显示的提示信息。


Processing, please wait …


pagination


boolean


True 就会在 datagrid 的底部显示分页栏。


false


rownumbers


boolean


True 就会显示行号的列。


false


singleSelect


boolean


True 就会只允许选中一行。


false


pageNumber


number


当设置了 pagination 特性时,初始化页码。


1


pageSize


number


当设置了 pagination 特性时,初始化页码尺寸。


10


pageList


array


当设置了 pagination 特性时,初始化页面尺寸的选择列表。


[10,20,30,40,50]


queryParams


object


当请求远程数据时,发送的额外参数。


{}


sortName


string


定义可以排序的列。


null


sortOrder


string


定义列的排序顺序,只能用 ‘asc‘ 或 ‘desc‘。


asc


remoteSort


boolean


定义是否从服务器给数据排序。


true


showFooter


boolean


定义是否显示一行页脚。


false


rowStyler


function


返回例如 ‘background:red‘ 的样式,该函数需要两个参数: rowIndex: 行的索引,从 0 开始。 rowData: 此行相应的记录。


loadFilter


function


返回过滤的数据去显示。这个函数需要一个参数 ‘data‘ ,表示原始数据。

你可以把原始数据变成标准数据格式,此函数必须返回标准数据对象,含有 ‘total‘ 和 ‘rows‘ 特性。


editors


object


定义编辑行时的 editor 。


预定义的 editor


view


object


定义 datagrid 的 view 。


默认的 view

列(Column)的特性
DataGrid 的 Column 是一个数组对象,它的每个元素也是一个数组。数组元素的元素是一个配置对象,它定义了每个列的字段。 代码示例:

复制代码 代码如下:

columns:[[

   {field:‘itemid‘,title:‘Item ID‘,rowspan:2,width:80,sortable:true},

   {field:‘productid‘,title:‘Product ID‘,rowspan:2,width:80,sortable:true},

   {title:‘Item Details‘,colspan:4}
],[

   {field:‘listprice‘,title:‘List Price‘,width:80,align:‘right‘,sortable:true},

   {field:‘unitcost‘,title:‘Unit Cost‘,width:80,align:‘right‘,sortable:true},
  {field:‘attr1‘,title:‘Attribute‘,width:100},
  {field:‘status‘,title:‘Status‘,width:60} ]]


名称


类型


说明


默认值


title


string


列的标题文字。


undefined


field


string


列的字段名。


undefined


width


number


列的宽度。


undefined


rowspan


number


指一个单元格占据多少行。


undefined


colspan


number


指一个单元格占据多少列。


undefined


align


string


指如何对齐此列的数据,可以用 ‘left‘、‘right‘、‘center‘。


undefined


sortable


boolean


True 就允许此列被排序。


undefined


resizable


boolean


True 就允许此列被调整尺寸。


undefined


hidden


boolean


True 就隐藏此列。


undefined


checkbox


boolean


True 就显示 checkbox。


undefined


formatter


function


单元格的格式化函数,需要三个参数:
value: 字段的值。 rowData: 行的记录数据。 rowIndex: 行的索引。


undefined


styler


function


单元格的样式函数,返回样式字符串来自定义此单元格的样式,例如 ‘background:red‘ 。此函数需要三个参数: value: 字段的值。 rowData: 行的记录数据。 rowIndex: 行的索引。


undefined


sorter


function


自定义字段的排序函数,需要两个参数: a: 第一个字段值。 b: 第二个字段值。


undefined


editor


string,object


指编辑类型。当是 string 时指编辑类型,当 object 时包含两个特性:
type:string,编辑类型,可能的类型是:

text、textarea、checkbox、numberbox、validatebox、datebox、combobox、combotree。 options:对象,编辑类型对应的编辑器选项。


undefined

编辑器(Editor)
用 $.fn.datagrid.defaults.editors 重写了 defaults。
每个编辑器有下列行为:


名称


参数


说明


init


container, options


初始化编辑器并且返回目标对象。


destroy


target


如果必要就销毁编辑器。


getValue


target


从编辑器的文本返回值。


setValue


target , value


给编辑器设置值。


resize


target , width


如果必要就调整编辑器的尺寸。

例如,文本编辑器(text editor)像下面这样定义:

复制代码 代码如下:

$.extend($.fn.datagrid.defaults.editors, {
text: { init: function(container, options){ var input = $(‘<input type="text" class="datagrid-editable-input">‘).appendTo(container);
return input; }, getValue: function(target){ return $(target).val(); }, setValue: function(target, value){
$(target).val(value); }, resize: function(target, width){ var input = $(target); if ($.boxModel == true){ input.width(width - (input.outerWidth() - input.width())); } else { input.width(width);
} } } });

数据表格视图(DataGrid View) 用 $.fn.datagrid.defaults.view 重写了 defaults。 view 是一个对象,它告诉 datagrid 如何呈现行。这个对象必须定义下列方法。


名称


参数


说明


render


target, container, frozen


当数据加载时调用。 target:DOM 对象,datagrid 对象。 container:行的容器。 frozen:表示是否呈现冻结容器。


renderFooter


target, container, frozen


这是呈现行脚选项的函数。


renderRow


target, fields, frozen, rowIndex, rowData


这是选项的函数,将会被 render 函数调用。


refreshRow


target, rowIndex


定义如何刷新指定的行。


onBeforeRender


target, rows


视图被呈现前触发。


onAfterRender


target


视图被呈现后触发。

事件
其事件扩展自 panel,下列是为 datagrid 增加的事件。


名称


参数


说明


onLoadSuccess


data


当数据加载成功时触发。


onLoadError


none


加载远程数据发生某些错误时触发。


onBeforeLoad


param


发送加载数据的请求前触发,如果返回 false加载动作就会取消。


onClickRow


rowIndex, rowData


当用户点击一行时触发,参数包括: rowIndex:被点击行的索引,从 0 开始。 rowData:被点击行对应的记录。


onDblClickRow


rowIndex, rowData


当用户双击一行时触发,参数包括: rowIndex:被双击行的索引,从 0 开始。 rowData:被双击行对应的记录。


onClickCell


rowIndex, field, value


当用户单击一个单元格时触发。


onDblClickCell


rowIndex, field, value


当用户双击一个单元格时触发。


onSortColumn


sort, order


当用户对一列进行排序时触发,参数包括: sort:排序的列的字段名 order:排序的列的顺序


onResizeColumn


field, width


当用户调整列的尺寸时触发。


onSelect


rowIndex, rowData


当用户选中一行时触发,参数包括: rowIndex:选中行的索引,从 0 开始 rowData:选中行对应的记录


onUnselect


rowIndex, rowData


当用户取消选择一行时触发,参数包括: rowIndex:取消选中行的索引,从 0 开始 rowData:取消选中行对应的记录


onSelectAll


rows


当用户选中全部行时触发。


onUnselectAll


rows


当用户取消选中全部行时触发。


onBeforeEdit


rowIndex, rowData


当用户开始编辑一行时触发,参数包括: rowIndex:编辑行的索引,从 0 开始 rowData:编辑行对应的记录


onAfterEdit


rowIndex, rowData, changes


当用户完成编辑一行时触发,参数包括: rowIndex:编辑行的索引,从 0 开始 rowData:编辑行对应的记录 changes:更改的字段/值对


onCancelEdit


rowIndex, rowData


当用户取消编辑一行时触发,参数包括: rowIndex:编辑行的索引,从 0 开始 rowData:编辑行对应的记录


onHeaderContextMenu


e, field


当 datagrid 的头部被右键单击时触发。


onRowContextMenu


e, rowIndex, rowData


当右键点击行时触发。

方法


名称


参数


说明


options


none


返回 options 对象。


getPager


none


返回 pager 对象。


getPanel


none


返回 panel 对象。


getColumnFields


frozen


返回列的字段,如果 frozen 设定为 true,冻结列的字段被返回。


getColumnOption


field


返回指定列的选项。


resize


param


调整尺寸和布局。


load


param


加载并显示第一页的行,如果指定 param 参数,它将替换 queryParams 特性。


reload


param


重新加载行,就像 load 方法一样,但是保持在当前页。


reloadFooter


footer


重新加载脚部的行。


loading


none


显示正在加载状态。


loaded


none


隐藏正在加载状态。


fitColumns


none


使列自动展开/折叠以适应 datagrid 的宽度。


fixColumnSize


none


固定列的尺寸。


fixRowHeight


index


固定指定行的高度。


loadData


data


加载本地数据,旧的行会被移除。


getData


none


返回加载的数据。


getRows


none


返回当前页的行。


getFooterRows


none


返回脚部的行。


getRowIndex


row


返回指定行的索引,row 参数可以是一个行记录或者一个 id 字段的值。


getSelected


none


返回第一个选中的行或者 null。


getSelections


none


返回所有选中的行,当没有选中的记录时,将返回空数组。


clearSelections


none


清除所有的选择。


selectAll


none


选中当前页所有的行。


unselectAll


none


取消选中当前页所有的行。


selectRow


index


选中一行,行索引从 0 开始。


selectRecord


idValue


通过 id 的值做参数选中一行。


unselectRow


index


取消选中一行。


beginEdit


index


开始对一行进行编辑。


endEdit


index


结束对一行进行编辑。


cancelEdit


index


取消对一行进行编辑。


getEditors


index


获取指定行的编辑器们。每个编辑器有下列特性: actions:编辑器能做的动作们。 target:目标编辑器的 jQuery 对象。 field:字段名。 type:编辑器的类型。


getEditor


options


获取指定的编辑器, options 参数包含两个特性: index:行的索引。 field:字段名。


refreshRow


index


刷新一行。


validateRow


index


验证指定的行,有效时返回 true。


updateRow


param


更新指定的行, param 参数包含下列特性: index:更新行的索引。 row:行的新数据。


appendRow


row


追加一个新行。


insertRow


param


插入一个新行, param 参数包括下列特性: index:插入进去的行的索引,如果没有定义,就追加此新行。 row:行的数据。


deleteRow


index


删除一行。


getChanges


type


获取最后一次提交以来更改的行,type 参数表示更改的行的类型,可能的值是:inserted、deleted、updated,等等。

当 type 参数没有分配时,返回所有改变的行。


acceptChanges


none


提交自从被加载以来或最后一次调用acceptChanges以来所有更改的数据。


rejectChanges


none


回滚自从创建以来或最后一次调用acceptChanges以来所有更改的数据。


mergeCells


options


把一些单元格合并为一个单元格,options 参数包括下列特性: index:列的索引。 field:字段名。 rowspan:合并跨越的行数。 colspan:合并跨越的列数。


showColumn


field


显示指定的列。


hideColumn


field


隐藏指定的列。

时间: 2024-10-11 12:42:06

EasyUI后台管理系统学习三的相关文章

EasyUI后台管理系统学习一

有时候写点东西还是有必要的.接上次写的那个伪静态的学习,今天写写用EasyUI这个框架做那个后台系统的一点成果.在学习中还是有很多收获的,今天就写写自己对这个源码的组织发点感想吧: 第一个是内部代码组织部分,多层架构这个是第一感觉,分实体部分.业务逻辑部分.数据访问类等.这个可以在很多系统源码中看到这样的架构,这种架构没有什么特别之处,自我感觉就是把以前(我自己)写作一坨的业务处理其他的代码都分开了,封装了.基本思想还是增删改查. 第二.用到了实体类.这个也不是什么新鲜玩意.跟MVC中差不多,学

EasyUI后台管理系统学习四

上午写了点EasyUI下datagrid的绑定的东东,单独运行的时候居然不显示,就是说通过IIS解析打开并不绑定数据,奇怪了,后来在网上找到一篇文章解决了这个问题,其实说实在的,如果要自己去摸索,肯定还是要去网络看那个指南什么的,其实有时候觉得拿来主义并不是那么的卑鄙,如果任何知识都是自己的发明那就没有拿来主义,况且,我们现在用的WINDOWS都是拿来主义.不纠结这个拿来不拿来的问题了,直接上那个配置步骤(以下文章摘自他人,无任何商业目的): 这段时间学些easyui,用IIS调试的时候,发现I

ASP.NET MVC5+EF6+EasyUI 后台管理系统(1)-前言与目录(持续更新中...)

开发工具:VS2015(2012以上)+SQL2008R2以上数据库  您可以有偿获取一份最新源码联系QQ:729994997 价格 666RMB  升级后界面效果如下: 日程管理   http://www.cnblogs.com/ymnets/p/7094914.html 任务调度系统界面 http://www.cnblogs.com/ymnets/p/5065154.html 系统权限全套完整图  http://www.cnblogs.com/ymnets/p/5065201.html 系统

ASP.NET MVC5+EF6+EasyUI 后台管理系统-关于WebApi的用法

1:ASP.NET MVC5+EF6+EasyUI 后台管理系统(1)-WebApi与Unity注入 使用Unity是为了使用我们后台的BLL和DAL层 2:ASP.NET MVC5+EF6+EasyUI 后台管理系统(2)-WebApi与Unity注入-配置文件 3:ASP.NET MVC5+EF6+EasyUI 后台管理系统(3)-MVC WebApi 用户验证 (1) 4:ASP.NET MVC5+EF6+EasyUI 后台管理系统(4)-MVC WebApi 用户验证 (2) 以往我们讲

ASP.NET MVC5+EF6+EasyUI 后台管理系统(92)-打印EasyUI 的datagrid表格

前言 应用系统有时候需要打印Datagrid的表格内容,我们本节就来学习打印datagrid内容 打印主要使用:web打印(我们之前有讲过web打印插件jqprint) + 将datagrid重新编制成可以打印的html格式 一.建立一个普通的例子 我们使用官方下载的demo下的datagrid basic.html代码就好 引入Jqgrid打印插件,并增加一个按钮来触发打印事件 <!DOCTYPE html> <html> <head> <meta charse

ASP.NET MVC5+EF6+EasyUI 后台管理系统(75)-微信公众平台开发-用户管理

最近代码出现分享问题,360云盘宣布混不下去,所有分享的连接都失效了,最近有时间会把代码转移到百度云,再把文章的代码补回去 前言 本节主要是关注者(即用户)和用户组的管理,微信公众号提供了用户和用户组的管理,我们可以在微信公众号官方里面进行操作,添加备注和标签,以及移动用户组别,同时,微信公众号也提供了相应的接口另我们本地可以操作.我们主要是同步到本地,这样我们可以自己为用户定义更多的信息,以及与本地的业务更好的对接起来. 实现 一.关注与订阅事件 看到我们之前的消息处理类 我们需要扩展一个事件

EasyUI - 后台管理系统 - 增加,删除,修改

效果: html代码: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="admin.aspx.cs" Inherits="EasyUI.Application.admin" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <

ASP.NET MVC5+EF6+EasyUI 后台管理系统(84)-Quartz 作业调度用法详解一

前言 我从Quartz2.0开始使用,并对其进行了封装了界面,可以参考 http://www.cnblogs.com/ymnets/p/5065154.html 最近拿出来进行了优化,并升级到最新版,温故而知新嘛 当初教程较少,并且是英文,现在很多地方都有中文的教程也是学习起来事半功倍 Quartz能实现什么? 他类似于SQL Server的代理与Timer定时器: 1.指定时间执行一条SQL语句或存储过程 2.指定时间发送邮件(执行一个C#方法) 3.有规律的定时执行想要做的事情(通过配置Cr

EasyUI - 后台管理系统 - 登陆模块

效果: --- --- Html代码: <div id="login"> <p>账户:<input type="text" id="user" /></p> <p>密码:<input type="password" id="pwd" /></p> </div> <div id="btn"