Jquery Easy UI初步学习(三)数据增删改

第二篇只是学了加载用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>0)
            {
                //修改
                if (new CrmUserBll().Update(crmUser) > 0)
                {
                    return Content("ok");
                }
            }
}

来自为知笔记(Wiz)

Jquery Easy UI初步学习(三)数据增删改

时间: 2024-10-17 22:27:15

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

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

第一篇学的是做一个管理的外框,接着就是数据datagrid绑定了,这里我用asp.net mvc3来做的,主要就是熟悉属性.方法. 打开easyui的demo 就可以看到如下一段代码: 和上篇一样class="easyui-datagrid", data-options="...",这是一样的,其他我在网上查了查,并做了整理 DataGrid 属性 参数名 类型 描述 默认值 title string Datagrid面板的标题 null iconCls strin

Jquery Easy UI初步学习(一)

Easy UI 1.3.2 以前听说Easy UI很不错,当了一个dome,闲着没事就看了一下,也整理一下为了自己更好的记忆,也希望对象我这样小菜有帮助吧 先从后台管理的主页面开始,如要要做主页需要了解以下几项 data-options是jQuery Easyui 最近两个版本才加上的一个特殊属性.通过这个属性,我们可以对easyui组件的实例化可以完全写入到html中,例如: <div class="easyui-dialog" style="width:400px;

jquery easy UI 的hello版

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Tree Node Icons - jQuery EasyUI Demo</title> <link rel="stylesheet" type="text/css" href="easyui.css"> <link r

Jquery Easy UI的初步使用

总的来说,easyUI是jquery的一个很好地扩展,大大的提高了代码的开发速度,是一个很好地插件,我在使用的过程中,总体的感觉还是很不错的. 虽然相对来说,文件包稍微的有点大,但是在现在的网络世界中,这点大小就显得微不足道了,所以,在前端设计方面还是有很多的优势. 下面是一个easyUI的初步实例: <!DOCTYPE html> <html> <head> <title>Jquery Easy UI</title> <meta char

jQuery Easy UI Panel(面板)组件

panel(面板)组件,跟前面的组件用法几乎都差不多,也是从设置一些面板属性.操作面板触发的事件.我们可针对面板对象的操作方法这三个点去学习. 后面有一些组件要依赖于这个组件. 还有一点跟前面不同的就是面板内容可以请求远程数据. 示例: <!DOCTYPE html> <html> <head> <title>jQuery Easy UI</title> <meta charset="UTF-8" /> <s

jQuery Easy UI整理笔记目录

jQuery Easy UI整理笔记目录 ps:最近对Easy UI比较感兴趣,打算系统的学习一下,前面基础部分的东西很简单,都是参照API去写的,例子也就是随便举的,没有列举项目中的实际应用. 打算基础部分后面的知识多投入点时间,多与项目中的实际相结合一些,也尽量多想象出一些应用场景. 计划最慢每周更新一篇文章. 一.基础组件部分 1. jQuery Easy UI的使用 2. jQuery Easy UI Draggable(拖动)组件 3. jQuery Easy UI Droppable

JQuery Easy Ui (Tree树)详解

在这里沉重悼念我辛辛苦苦写了4个小时的文章,因为我的失误,没保存,而夭折啦..... 我的痛苦谁能懂? 哎~~~~  吃一见长一智吧! 么的办法啊! 但是,但是!我狠了狠心,咬了咬牙!我决定,再写一遍!!! 谁知道哭的表情怎么写! 我已经无法用言语表达我此时此刻的沉重心情了! (以下内容,身为菜鸟的我是用颤抖的双手敲出来的,忘同志们珍惜!!!!) 记得4个小时之前,我写过一个随笔,它的内容是这样的: 每次写博客,都喜欢在前面和大家分享一些东西,今天要分享的是一个小故事: 一个世界著名的大酒店正在

jQuery Easy UI的使用

一.初步认识 1.什么是jQuery Easy UI jQuery Easy UI是一组基于jQuery的UI插件集合,而jQuery Easy UI 的目标就是帮助Web 开发者更轻松的打造出功能丰富并且美观的 UI 界面. 官方网站http://www.jeasyui.com 2.jQuery EasyUI有哪些特点 (1).基于 jquery 用户界面插件的集合: (2).源代码加密.商业版付费 (3).使用 EasyUI 你不需要写很多的 javascript 代码,通常只需要写 HTM

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

JQuery Easy Ui (Tree树)详解(转) 第一讲:JQuery Easy Ui到底是什么呢? 首先咱们知道JQuery是对Java Script的封装,是一个js库,主要提供的功能是选择器,属性修改和事件绑定等等.. JQuery ui是在jQuery的基础上,利用jQuery的扩展性,设计的插件. 那么JQuery Easy Ui到底是什么呢? 我的理解就是比JQuery ui更强大,同样都是实现绚丽的多功能效果! jQuery Easy UI的目的就是帮助Web开发者更轻松的打