第二篇只是学了加载用datagrid加载数据,数据的增删改还没有做,今天主要是解决这个问题了。

在做增删改前需要弹出对应窗口,这就需要了解一下EasyUi的弹窗控件。
摘自:http://philoo.cnblogs.com/
我的理解,就是panel有的属性Window、dialog都有,同时保留自己的扩展属性方法 , 所以主要展示pannel的属性。

Pannel 属性

名称 类型 说明 默认值
title string 显示在Panel头部的标题文字。 null
iconCls string 在Panel里显示一个16x16图标的CSS类。 null
width number 设置Panel的宽度。 auto
height number 设置Panel的高度。 auto
left number 设置Panel的左边位置。 null
top number 设置Panel的顶部位置。 null
cls string 给Panel增加一个CSS类。 null
headerCls string 给Panel头部增加一个CSS类。 null
bodyCls string 给Panel身体增加一个CSS类。 null
style object 给Panel增加自定义格式的样式。 {}
fit boolean 当设为true时,Panel的 尺寸就适应它的父容器。 FALSE
border boolean 定义了是否显示Panel的边框。 TRUE
doSize boolean 设置为true,创建时Panel就调整尺寸并做成布局。 TRUE
noheader boolean 要是设置为true,Panel的头部将不会被创建。 FALSE
content string Panel身体的内容。 null
collapsible boolean 定义了是否显示折叠按钮。 FALSE
minimizable boolean 定义了是否显示最小化按钮。 FALSE
maximizable boolean 定义了是否显示最大化按钮。 FALSE
closable boolean 定义了是否显示关闭按钮。 FALSE
tools array 自定义工具组,每个工具包含两个特性: [ ]
iconCls和handler
collapsed boolean 定义了初始化Panel是不是折叠的。 FALSE
minimized boolean 定义了初始化Panel是不是最小化的。 FALSE
maximized boolean 定义了初始化Panel是不是最大化的。 FALSE
closed boolean 定义了初始化Panel是不是关闭的。 FALSE
href string 一个URL,用它加载远程数据并且显示在Panel里。 null
cache boolean 设置为true就缓存从href加载的Panel内容。 TRUE
loadingMessage string 当加载远程数据时在Panel里显示的一条信息。 Loading…
extractor function 定义了如何从ajax响应抽出内容,返回抽出的数据。
extractor: function(data){
 var pattern = /<body[^>]*>((.|[\n\r])*)<\/body>/im;
 var matches = pattern.exec(data);
 if (matches){
 return matches[1]; // 只抽出 body 的内容
 } else {
 return data;
 }
}
 

Pannel 事件

名称 参数 说明
onLoad none 当远程数据被加载时触发。
onBeforeOpen none Panel打开前触发,返回false就停止打开。
onOpen none Panel打开后触发。
onBeforeClose none Panel关闭前触发,返回false就取消关闭。
onClose none Panel关闭后触发。
onBeforeDestroy none Panel销毁前触发,返回false就取消销毁。
onDestroy none Panel销毁后触发。
onBeforeCollapse none Panel折叠前触发,返回false就停止折叠。
onCollapse none Panel折叠后触发。
onBeforeExpand none Panel展开前触发,返回false就停止展开。
onExpand none Panel展开后触发。
onResize width, height Panel调整尺寸后触发。
width:新的外部宽度。
height:新的外部高度
onMove left,top Panel移动后触发。
left:新的左边位置
Top:新的顶部位置
onMaximize none 窗口最大化后触发。
onRestore none 窗口还原为它的原始尺寸后触发。
onMinimize none 窗口最小化后触发。

Pannel 方法

名称 参数 说明
options none 返回选项特性。
panel none 返回Panel对象。
header none 返回Panel头部对象。
body none 返回Panel身体对象。
setTitle title 设置头部的标题文字。
open forceOpen 当forceOpen参数设为true,就绕过onBeforeOpen回调函数打开Panel。
close forceClose 当forceClose参数设为true,就绕过onBeforeClose回调函数关闭Panel。
destroy forceDestroy 当forceDestroy参数设为true,就绕过onBeforeDestroy回调函数销毁Panel。
refresh href 当设置了href特性时,刷新Panel加载远程数据。
resize options 设置Panel尺寸并做布局。Options对象包含下列特性:
width:新的Panel宽度
height:新的Panel高度
left:新的Panel左边位置
top:新的Panel顶部位置
move options 移动Panel到新位置。Options对象包含下列特性:
left:新的Panel左边位置
top:新的Panel顶部位置
maximize none Panel适应它的容器的尺寸。
minimize none 最小化Panel。
restore none 把最大化的Panel还原为它原来的尺寸和位置。
collapse animate 折叠Panel身体。
expand animate 展开Panel身体。

转自:http://www.cnblogs.com/hantianwei/archive/2012/03/19/2407047.html

Window 属性

参数名 类型 描述
modal boolean 是否生成模态窗口。默认false
shadow boolean 是否显示窗口阴影。默认false

Dialog  属性

参数名 类型 描述
title string 该对话框标题文本。默认"New Dialog"
collapsible boolean 当True时可显示折叠按钮。默认false
minimizable boolean 当True时可显示最小化按钮。默认false
maximizable boolean 当True时可显示最大化按钮。默认false
resizable boolean 当True时能重绘对话框大小。默认false
toolbar array 该工具栏置于对话框的顶部,每个工具栏包含:text, iconCls, disabled, handler等属性
buttons array 这个按钮置于对话框的底部,每个按钮包含:text, iconCls, handler等属性
这里我用的是Dialog,这里也只说修改,因为修改解决了,其他也就没问题了.

修改数据

先看看dome中怎么用的
    
现在要实现点击Datagrid中一行把数据加载到表单上,有两种方案
用户修改页面:
<div id="grid" class="easyui-grid" ></div>
<div id="EditDig" class="easyui-dialog" style="width:400px;height:350px;" closed="true" ></div>
> 一种用easyui Datagird中自带方法,获取选中行,将选中行的数据加载到dialog的from表单中
function editUser() {
     var row = $('#dg').datagrid('getSelected');
     if (row) {
        $('#EditDig').dialog('open');
         $('#toUpdate').form('load', row);
     }
}
用这种需要Datagrid中field的值与form中name对应就可以加载了。
> 还有就是只是获取选中行id,然后根据id去查询加载数据,我觉得这个更贴进mvc
function edit(Id) {
    $("#EditDig").dialog({
        title: '用户修改',
        href: '/CrmUser/Edit?id=' + pId,
        iconCls: 'icon-edit',
        modal: true,
        closed: false
    });
}
弹出窗口页面:
@model GroupItem.Model.CrmUserEntity
<style type="text/css">
tr{ height: 30px;}
.td_txt{ text-align:right;}
</style>
<script type="text/javascript">
function closeForm () {
$('#EditDig').dialog('close');
}
</script>
<form id="toUpdate" method="POST">
<table style="width: 100%; padding: 0 10px;">
<tr>
<td width="10" class="td_txt">登陆邮箱:</td>
<td width="40">@Html.TextBoxFor(t => t.LoginEmail)</td>
<td width="30">@Html.ValidationMessageFor(t=>t.LoginEmail)</td>
</tr>
<tr>
<td class="td_txt">真实姓名:</td>
<td>@Html.TextBoxFor(t => t.TrueName)</td>
<td>@Html.ValidationMessageFor(t => t.TrueName)</td>
</tr>
<tr>
<td class="td_txt">昵称:</td>
<td>@Html.TextBoxFor(t => t.NickName)</td>
<td></td>
</tr>
<tr>
<td class="td_txt">手机号码:</td>
<td>@Html.TextBoxFor(t => t.Phone)</td>
<td></td>
</tr>
<tr>
<td class="td_txt">身份证:</td>
<td>@Html.TextBoxFor(t => t.UserCard)</td>
<td></td>
</tr>
<tr>
<td class="td_txt">QQ号码:</td>
<td>@Html.TextBoxFor(t => t.QQ)</td>
<td></td>
</tr>
<tr>
<td class="td_txt">最后登陆时间:</td>
<td>@Html.TextBoxFor(t => t.LastLoginTime)</td>
<td></td>
</tr>
<tr>
<td colspan="3" style="text-align: center;">
<input type="button" value="保存" onclick="toSubmit()" />&nbsp;&nbsp;
<input type="button" value="取消" onclick=" closeForm() "/>
</td>
</tr>
</table>
</form> <script type="text/javascript">
function toSubmit() {
var posData = $("#toUpdate").serializeArray();
$.post("/CrmUser/Edit", posData, function (date) {
if (date == "ok") {
closeForm();
$("#grid").datagrid('reload');
} else {
$.messager.alert("友情提示", "操作失败,请您检查", "error");
}
});
}
</script>

控制器:

/// <summary>
/// 用户信息修改
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public ActionResult Edit(int? id)
{
var model = new CrmUserEntity();
if (id.HasValue)
{
model = new CrmUserBll().Get(id.Value);
}
return View(model);
}
/// <summary>
/// 用户信息修改
/// </summary>
/// <param name="crmUser"></param>
/// <returns></returns>
[HttpPost]
[ValidateInput(false)]
public ActionResult Edit(CrmUserEntity crmUser)
{
if (crmUser.Id>)
{
//修改
if (new CrmUserBll().Update(crmUser) > )
{
return Content("ok");
}
}
}

Jquery Easy UI初步学习(三)数据增删改的更多相关文章

  1. Jquery Easy UI初步学习(一)

    Easy UI 1.3.2 以前听说Easy UI很不错,当了一个dome,闲着没事就看了一下,也整理一下为了自己更好的记忆,也希望对象我这样小菜有帮助吧 先从后台管理的主页面开始,如要要做主页需要了 ...

  2. Jquery Easy UI初步学习(二)datagrid的使用

    第一篇学的是做一个管理的外框,接着就是数据datagrid绑定了,这里我用asp.net mvc3来做的,主要就是熟悉属性.方法. 打开easyui的demo 就可以看到如下一段代码: 和上篇一样cl ...

  3. Jquery easy UI 上中下三栏布局 分类: ASP.NET 2015-02-06 09:19 368人阅读 评论(0) 收藏

    效果图: 源代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://w ...

  4. jquery easy ui 1.3.4 数据表格(DataGrid)(8)

    8.1.创建DataGrid html代码 <table id="dg"></table> $("#dg").datagrid({ // ...

  5. JQuery Easy Ui dataGrid 数据表格 ---制作查询下拉菜单

    JQuery Easy Ui dataGrid 数据表格 数据表格 - DataGrid 继承$.fn.panel.defaults,使用$.fn.datagrid.defaults重载默认值.. 数 ...

  6. jQuery Easy UI Panel(面板)组件

    panel(面板)组件,跟前面的组件使用方法差点儿都差点儿相同,也是从设置一些面板属性.操作面板触发的事件.我们可针对面板对象的操作方法这三个点去学习. 后面有一些组件要依赖于这个组件. 另一点跟前面 ...

  7. JQuery Easy Ui (Tree树)详解(转)

    第一讲:JQuery Easy Ui到底是什么呢? 首先咱们知道JQuery是对Java Script的封装,是一个js库,主要提供的功能是选择器,属性修改和事件绑定等等.. JQuery ui是在j ...

  8. salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建

    VisualForce封装了很多的标签用来进行页面设计,本篇主要讲述简单的页面增删改查.使用的内容和设计到前台页面使用的标签相对简单,如果需要深入了解VF相关知识以及标签, 可以通过以下链接查看或下载 ...

  9. jQuery Easy UI 开发笔记

    1.jQuery Easy UI主要的运行原理是通过核心的代码调用插件来实现UI效果的 2.jQuery Easy UI插件与插件之间的关系是: 一.独立式插件: 独立式插件是指:不与其他的插件具有相 ...

随机推荐

  1. 使用libxml2进行xml开发(一)

    (一)Windows下使用MinGW和Code::Blocks环境配置libxml2 笔者此次是在windows 7下使用MinGW和Code::Blocks开发C程式的,手上的一个项目需要使用soc ...

  2. Android UI/UX 工具

    Zeplin 用于界面图片自动导出. 图标 : https://material.io/icons/

  3. template(定义类的模板关键字)

    template<typename T1> template<class T1> 在一般情况下二者使用方式是一样的,但有一个特例:就是当T1是一个类的时候,而这个类又有子类时候 ...

  4. Mysql的Text和Blob的比较

    MySQL存在text和blob: (1)相同 在TEXT或BLOB列的存储或检索过程中,不存在大小写转换,当未运行在严格模式时,如果你为BLOB或TEXT列分配一个超过该列类型的最大长度的值,值被截 ...

  5. MySQL(视图、触发器、函数)

    day61 参考:http://www.cnblogs.com/wupeiqi/articles/5713323.html 视图 视图:给某个查询语句设置别名,日后方便使用               ...

  6. 听补天漏洞审核专家实战讲解XXE漏洞

    对于将“挖洞”作为施展自身才干.展现自身价值方式的白 帽 子来说,听漏洞审核专家讲如何挖掘并验证漏洞,绝对不失为一种快速的成长方式! XXE Injection(XML External Entity ...

  7. 修正eth0,解决虚拟机桥接问题

    centos 中没有 ifcfg-eth0 配置文件的解决办法 1.也就是说是centos6改用NetworkManager方式管理网络了,可以运行如下命令进行确认: chkconfig --list ...

  8. HTML简单登录和注册页面及input标签诠释

    今天第一次接触HTML这种语言,虽然不能完全理解其中的意思,过去学的英语单词几乎也忘了差不多了,但是感觉进入这门语言学习之后就没有那么难了,一步一步来吧!下面巩固下今天学内容: HTML是一种超文本标 ...

  9. WPF一步步开发XMPP IM客户端1:入门

    [起因&目标] 因为工作原因接触openfire服务端和spark客户端开发,主要是基于openfire扩展开发了针对企业用途的服务器插件,还开发了各个平台上的客户端(Windows\mac\ ...

  10. Python初体验(一)—【配置环境变量】【变量】【input】【条件语句】【循环语句】

    写在前面的: 作为一个控制专业的女研究生,不知道每天在研究什么,但总归逃脱不了码代码的命运.之前也学习过一些C语言.C++,基础嘛,稍稍微有一些.本不想走上码农的道路,天真烂漫的过此生(白日梦过程中. ...