Easyui主从表设计

js代码:

// 全局变量
var loading;
var grid;
var mainGrid;
var dlg_Edit;
var dlg_Edit_form;
var virpath = ""; //网站的虚拟目录 如:/ShopManager
var permissions;
var addPermissionName = ‘City_Add‘.toLowerCase();
var editPermissionName = ‘City_Edit‘.toLowerCase();
var delPermissionName = ‘City_Delete‘.toLowerCase();
var savePermissionName = ‘City_Save‘.toLowerCase();
var exportPermissionName = ‘City_PrintandExport‘.toLowerCase();
var curRowData;
var lastIndex;

$(function () {

    dlg_Edit = $(‘#Dlg-Edit‘).dialog({
        closed: true,
        modal: true,
        toolbar: [{
            text: ‘保存‘,
            iconCls: ‘icon-save‘,
            handler: saveData
        }, ‘-‘, {
            text: ‘关闭‘,
            iconCls: ‘icon-no‘,
            handler: function () {
                dlg_Edit.dialog(‘close‘);
            }
        }],
        onBeforeLoad: function (param) {
            //var password = $("#ConcreteDType").attr("value");
        }
    }).dialog(‘center‘);
    dlg_Edit_form = dlg_Edit.find(‘form‘);

    $.ajax({
        url: virpath + ‘/admin/GetPermissionsForCurrentUser/?permissionKey=City‘,
        type: ‘post‘,
        datatype: ‘application/json; charset=utf-8‘,
        error: function (result) {
        },
        success: function (result) {
            permissions = result;
            grid = $(‘#grid‘).treegrid({
                rownumbers: true,
                fit: true,
                title: ‘城市列表‘,
                pagination: false,
                //pageSize: 20,
                fitColumns: true,
                singleSelect: true,
                striped: true,
                idField: "CityId",
                treeField: ‘Name‘,
                //sortName: ‘Sort‘,
                //sortOrder: ‘asc‘,
                //queryParams: { filter: ‘‘},
                datatype: ‘application/json; charset=utf-8‘,
                method: ‘get‘,
                toolbar: [{
                    text: ‘新增‘,
                    iconCls: ‘icon-add‘,
                    handler: add,
                    id: ‘btnAdd‘,
                    disable: true
                }, ‘-‘, {
                    text: ‘编辑‘,
                    iconCls: ‘icon-edit‘,
                    handler: edit,
                    id: ‘btnEdit‘,
                    disable: true
                }, ‘-‘, {
                    text: ‘删除‘,
                    iconCls: ‘icon-remove‘,
                    handler: del,
                    id: ‘btnDel‘,
                    disable: true
                }, ‘-‘, {
                    text: ‘刷新‘,
                    iconCls: ‘icon-search   ‘,
                    handler: reload
                }, ‘-‘],
                columns: [[
                            {
                                field: ‘Sort‘, title: ‘排序‘, width: 100, sortable: true

                            }
        , {
            field: ‘Name‘, title: ‘名称‘, width: 100, sortable: true

        }
        , {
            field: ‘Province‘, title: ‘所属省份‘, width: 100, sortable: false

        }
        , {
            field: ‘Pingyin‘, title: ‘拼音‘, width: 100, sortable: true

        }
        , {
            field: ‘Jiangpin‘, title: ‘简拼‘, width: 100, sortable: true

        }

                ]]
                ,
                onClickRow: function (row) {//运用单击事件实现一行的编辑结束,在该事件触发前会先执行onAfterEdit事件
                    var rowIndex = row.CityId;
                    if (lastIndex != rowIndex) {
                        grid.treegrid(‘endEdit‘, lastIndex);
                    }
                },
                onDblClickRow: function (row) { //双击事件
                    if (row == undefined) return;
                    var rowIndex = row.CityId;

                    if (lastIndex != rowIndex) {
                        grid.treegrid(‘endEdit‘, lastIndex);
                    }
                    var disabled = $(‘#btnEdit‘).linkbutton(‘options‘).disabled;
                    if (disabled || row.Predefined) {
                        grid.treegrid(‘cancelEdit‘, rowIndex);
                    } else {
                        grid.treegrid(‘beginEdit‘, rowIndex);
                    }

                    lastIndex = rowIndex;
                },
                onAfterEdit: function (row, changes) {
                    if (row.Predefined) return;
                    var rowId = row.CityId;
                    $.ajax({
                        url: virpath + ‘/api/City/Put/‘ + rowId,
                        data: row,
                        type: ‘put‘,
                        datatype: ‘application/json; charset=utf-8‘,
                        success: function (content) {
                            //result为请求处理后的返回值
                            var data = getObjectFrom(content);
                            if (data.success) {
                                Msgfade(‘操作成功‘); //提示消息
                                grid.treegrid(‘reload‘);

                            } else {
                                Msgalert(‘错误‘, data.msg, ‘error‘);
                            }
                        }
                    });
                },
                onBeforeLoad: function (param) {
                    setButtonPermissions(permissions);
                },
                onHeaderContextMenu: function (e, field) {
                    e.preventDefault();
                    if (!$(‘#tmenu‘).length) {
                        createColumnMenu();
                    }
                    $(‘#tmenu‘).menu(‘show‘, {
                        left: e.pageX,
                        top: e.pageY
                    });
                },
                onContextMenu: function (e, rowData) {
                    e.preventDefault();
                    curRowData = rowData;
                    if (!$(‘#rmenu‘).length) {
                        createRowContextMenu();
                    }
                    $(‘#rmenu‘).menu(‘show‘, {
                        left: e.pageX,
                        top: e.pageY
                    });
                },
                onLoadSuccess: function (data) { //当数据加载成功时触发

                },
                onLoadError: function (arguments) {
                    $.messager.alert(‘提示‘, ‘由于网络或服务器太忙,加载失败,请重试!‘, ‘error‘);
                }
            });
            mainGrid = $(‘#gridleft‘).datagrid({
                title: ‘省份‘,
                iconCls: ‘icon-save‘,
                method: ‘get‘,
                url: ‘/api/Province/Get‘,
                queryParams: { filter: ‘‘ },
                datatype: ‘application/json; charset=utf-8‘,
                idField: ‘ProvinceId‘,
                sortName: ‘ProvinceId‘,
                //sortOrder: ‘desc‘,
                sortOrder: ‘asc‘,
                pageSize: 30,
                striped: true,
                columns: [[
        {
            field: ‘Sort‘, title: ‘排序‘, width: 100, sortable: true

        }
        , {
            field: ‘Name‘, title: ‘名称‘, width: 100, sortable: true

        }
        , {
            field: ‘Pingyin‘, title: ‘拼音‘, width: 100, sortable: true

        }
        , {
            field: ‘Jiangpin‘, title: ‘简拼‘, width: 100, sortable: true

        }
                ]],
                fit: true,
                pagination: true,
                rownumbers: true,
                fitColumns: true,
                singleSelect: true,
                onSelect: function (rowIndex, rowData) {
                    showAll(rowData.ProvinceId);
                },
                onLoadSuccess: function (data) {
                    if (data.total > 0)
                        $(‘#gridleft‘).datagrid(‘selectRow‘, 0);
                },
                onLoadError: function () {
                    $.messager.alert(‘提示‘, ‘由于网络或服务器太忙,加载失败,请重试!‘, ‘error‘);
                },
                onBeforeLoad: function (param) {

                }
            });

        }
    });
});

function createColumnMenu() {
    var tmenu = $(‘<div id="tmenu" style="width:100px;"></div>‘).appendTo(‘body‘);
    var fields = grid.datagrid(‘getColumnFields‘);
    for (var i = 0; i < fields.length; i++) {
        $(‘<div iconCls="icon-ok"/>‘).html(fields[i]).appendTo(tmenu);
    }
    tmenu.menu({
        onClick: function (item) {
            if (item.iconCls == ‘icon-ok‘) {
                grid.datagrid(‘hideColumn‘, item.text);
                tmenu.menu(‘setIcon‘, {
                    target: item.target,
                    iconCls: ‘icon-empty‘
                });
            } else {
                grid.datagrid(‘showColumn‘, item.text);
                tmenu.menu(‘setIcon‘, {
                    target: item.target,
                    iconCls: ‘icon-ok‘
                });
            }
        }
    });
}
function getSelectedKey() {
    var rows = grid.datagrid(‘getSelections‘);
    if (rows.length == 0) return ‘‘;
    return rows[0].UserName;
}

function getSelectedArr() {
    var ids = [];
    var rows = grid.treegrid(‘getSelections‘);
    for (var i = 0; i < rows.length; i++) {
        ids.push(rows[i].CityId);
    }
    return ids;
}
function getSelectedID() {
    var ids = getSelectedArr();
    return ids.join(‘,‘);
}
function arr2str(arr) {
    return arr.join(‘,‘);
}

function add() {
    var rows = mainGrid.datagrid(‘getSelections‘);
    if (rows.length == 0) return;
    dlg_Edit.dialog(‘open‘).dialog(‘setTitle‘, ‘添加‘);
    dlg_Edit_form.form(‘clear‘);
    $("#ProvinceId").val(rows[0].ProvinceId);
    var parentRows = grid.datagrid(‘getSelections‘);
    if (parentRows.length > 0) {
        $("#ProvinceId").val(parentRows[0].CityId);
    }

    dlg_Edit_form.url = virpath + ‘/api/City/Post‘;
    dlg_Edit_form.method = ‘post‘;
}

function edit() {
    var rows = grid.datagrid(‘getSelections‘);
    var num = rows.length;
    if (num == 0) {
        Msgshow(‘请选择一条记录进行操作!‘);
        return;
    }
    else if (num > 1) {
        $.messager.alert(‘提示‘, ‘您选择了多条记录,只能选择一条记录进行修改!‘, ‘info‘);
        return;
    }
    else if (rows[0].Predefined) {
        $.messager.alert(‘提示‘, ‘预定义类型不允许修改!‘, ‘info‘);
        return;
    }
    else {
        dlg_Edit.dialog(‘open‘).dialog(‘setTitle‘, ‘修改:‘ + rows[0].Name);
        dlg_Edit_form.form(‘reset‘);
        dlg_Edit_form.form(‘load‘, rows[0]); //加载到表单的控件上
        dlg_Edit_form.method = ‘put‘;
        dlg_Edit_form.url = virpath + ‘/api/City/Put/‘ + rows[0].CityId;
    }
}

function del() {
    //var arr = getSelectedKey();
    var arr = getSelectedArr();
    //if (arr!=‘‘) {
    if (arr.length > 0) {
        var rows = grid.datagrid(‘getSelections‘);
        var num = rows.length;
        if (num == 0) {
            Msgshow(‘请选择一条记录进行操作!‘);
            return;
        }
        else if (rows[0].Predefined) {
            $.messager.alert(‘提示‘, ‘预定义类型不允许删除!‘, ‘info‘);
            return;
        }

        $.messager.confirm(‘提示‘, ‘您确认要删除选中的记录吗?‘, function (data) {
            if (data) {
                $.ajax({
                    //url: virpath + ‘/api/Categories/‘ + arr,
                    url: virpath + ‘/api/City/Delete/‘ + arr2str(arr),
                    type: ‘delete‘,
                    datatype: ‘application/json; charset=utf-8‘,
                    error: function (result) {
                        Msgalert(‘错误‘, ‘由于网络或服务器太忙,提交失败,请重试!‘, ‘error‘);
                        grid.datagrid(‘clearSelections‘);
                    },
                    success: function (content) {
                        //content为请求处理后的返回值
                        var result = getObjectFrom(content);
                        if (result.success) {
                            Msgfade(‘操作成功‘); //提示消息
                            grid.treegrid(‘reload‘);
                            grid.datagrid(‘clearSelections‘);
                        } else {
                            Msgalert(‘错误‘, result.msg, ‘error‘);
                        }
                    }
                });
            }
        });
    } else {
        Msgshow(‘请先选择要删除的记录。‘);
    }
}
function saveData() {
    dlg_Edit_form.form(‘submit‘, {
        url: dlg_Edit_form.url,
        onSubmit: function () {
            return $(this).form(‘validate‘);
        },
        //success:function(data) {alert(data)}
        success: function (content) {
            //content为请求处理后的返回值
            var result = getObjectFrom(content);
            if (result.success) {
                Msgfade(‘操作成功‘); //提示消息
                grid.treegrid(‘reload‘);
                dlg_Edit.dialog(‘close‘);
            } else {
                Msgalert(‘错误‘, result.msg, ‘error‘);
            }
        }
    });
}

function reload() {
    grid.treegrid(‘reload‘);
}
function showAll(ProvinceId) {
    grid.treegrid({ url: ‘/Api/City/Gett?ProvinceId=‘ + escape(ProvinceId) });
}
function getSelectedProvinceId() {
    var provinceId = ‘‘;
    var rows = $(‘#gridleft‘).datagrid(‘getSelections‘);
    if (rows.length > 0) {
        provinceId = rows[0].ProvinceId;
    }
    return provinceId;
}
function exportData() {
    var filter = getSelectedProvinceId();
    if (filter == ‘‘) return;
    window.blank = true;
    window.location = virpath + ‘/Api/City/GetExport/?provinceId=‘ + escape(filter) + ‘&recordCount=1000‘;
}

CSHTML代码

@{
    ViewBag.Title = "City";
    Layout = "~/Views/Shared/_LeftFixTowColumnLayout1.cshtml";
    ViewBag.AdminJsUrl = YbRapidSolution.Mvc.AutofacBootStrapper.RELEASE
                             ? @Url.Content("~/Scripts/Admin/City.min.js")
                             : @Url.Content("~/Scripts/Admin/City.js");
}
<div id="Dlg-Edit" title="窗口" style="width: 550px; height: 400px" buttons="#buttons">
    <div style="padding: 20px 40px 40px 0px;">
        <form method="POST" id="FormEdit">
            <input name="CityId" id="CityId" type="hidden" />
            <input name="ProvinceId" id="ProvinceId" type="hidden" />
            <table style="width: 100%">
                <tr>
                    <td class="text-right" style="width: 100px">名称:
                    </td>
                    <td>
                        <input type="text" name="Name" id="Name" class="easyui-validatebox easyui-textbox" data-options=‘required:true‘ maxlength="15" style="width: 100%" />
                    </td>
                </tr>
                <tr>
                    <td class="text-right">拼音:
                    </td>
                    <td>
                        <input type="text" name="Pingyin" id="Pingyin" class="easyui-validatebox easyui-textbox" maxlength="50" style="width: 100%" />
                    </td>
                </tr>
                <tr>
                    <td class="text-right">简拼:
                    </td>
                    <td>
                        <input type="text" name="Jiangpin" id="Jiangpin" class="easyui-validatebox easyui-textbox" maxlength="15" style="width: 100%" />
                    </td>
                </tr>
                <tr>
                    <td class="text-right">排序:
                    </td>
                    <td>
                        @* 货币参考配置:data-options="precision:2,groupSeparator:‘,‘,decimalSeparator:‘.‘,prefix:‘¥‘" style="width: 150px"/> *@
                        <input type="text" name="Sort" id="Sort" class="easyui-numberspinner" style="width: 150px" />
                    </td>
                </tr>
                <tr>
                    <td class="text-right">备注:
                    </td>
                    <td>
                        <textarea type="text" name="Description" id="Description" style="width: 100%; height: 300px" maxlength="1073741823"></textarea>
                    </td>
                </tr>
            </table>
        </form>
    </div>
</div>
<div id="buttons" style="padding: 10px">
    <a href="javascript:void(0)" class="easyui-linkbutton c1" iconcls="icon-save" type="PUT" onclick="saveData()">保存</a>
    <a href="javascript:void(0)" class="easyui-linkbutton c2" iconcls="icon-cancel" onclick="javascript:$(‘#Dlg-Edit‘).dialog(‘close‘)">关闭</a>
</div>

控制器中添加

        public IEnumerable<CityModel> Gett(int provinceId)
        {
            var items = _service.GetAll().Where(a => a.ProvinceId == provinceId).OrderBy(c => c.Sort);
            var model = items.ConvertTo(_convertCallback);
            return model;
        }

效果图

时间: 2024-12-27 06:27:19

Easyui主从表设计的相关文章

easyui主从表实现

今天用easyui做了一个主从表的查询,当然后续还会做编辑功能,用的是firefox debug ,感觉跟踪起来还是比较方便,以前做delphi开发,不用注意大小写问题,今天用easyui做前端时,让我痛苦了半天,前端的字段名用的大写,后端转来的json字段是小写,怎么搞数据都不显示,只是显示多少行,还有后台用的php,也是区分大小写的,post传的是大写参数名,处理POST参数时,却写的是小写参数名,一开始没留意,也是郁闷了半天才搞定. 以前做c/s程序开发,现在开发web的功能多了,感觉WE

表单(上)EasyUI Form 表单、EasyUI Validatebox 验证框、EasyUI Combobox 组合框、EasyUI Combo 组合、EasyUI Combotree 组合树

EasyUI Form 表单 通过 $.fn.form.defaults 重写默认的 defaults. 表单(form)提供多种方法来执行带有表单字段的动作,比如 ajax 提交.加载.清除,等等.当提交表单时,调用 'validate' 方法来检查表单是否有效. 用法 创建一个简单的 HTML 表单.构建表单并给 id.action.method 赋值. <form id="ff" method="post"> <div> <lab

DevExpress主从表 按组分页一组不足一页为一页--以此记录

本文的主要是说明Dev的报表的主从表,主从表的每一组显示在一页,当一组超出一页,第二页只显示第一组的. 一.每上报表设置图 简单设计图如上 二.后台代码 报表页代码 public partial class XtraReport1 : DevExpress.XtraReports.UI.XtraReport { public XtraReport1() { InitializeComponent(); } /// <summary> /// 设置主从表的数据源 /// </summary

优化Oracle数据库表设计

绝大多数的Oracle数据库性能问题都是由于数据库设计不合理造成的,只有少部分问题根植于Database Buffer.Share Pool.Redo Log Buffer等内存模块配置不合理,I/O争用,CPU争用等DBA职责范围上.所以除非是面对一个业已完成不可变更的系统,否则我们不应过多地将关注点投向内存.I/O.CPU等性能调整项目上,而应关注数据库表本身的设计是否合理,库表设计的合理性才是程序性能的真正执牛耳者.合理的数据库设计需要考虑以下的方面: ·业务数据以何种方式表达.如一个员工

如何快速的10分钟制作一张主从表单及功能

本文介绍如何使用快速开发平台建立一张主从表单页面 我们的网址:www.sdpsoft.com QQ:136846796 电话:15050176512 1.建立数据源 新建一张"测试_奖励管理_主表_页面"的数据源: 点击同步字段可以将此表中的字段同步过来(如图所示) 新建一张"测试_奖励管理_从表_页面"的数据源 2.在页面设计中制作页面 新建一张页面配置其信息 页面类型选择主从表单类型 脚本引用:test.js 添加数据集合(数据源): 主表信息 并且通过&quo

MySql主从表的主表删除数据

1.第一种: 解除主从表的约束关键 一般来说,在我们给主表添加外键时,切记要设计"外键名称",以便于日后可以删除外键约束. 声明外键约束语法: alter table 从表名 add [constraint] [外键名称] foreign key(从表中的外键字段名) references 主表(主表的主键); 删除外键约束: alter table 从表名 drop foreign key 外键名称; 2.第二种: 先删除从表中与主表有关系的数据,再删除主表中的数据(具体自己操作).

MySQL的多表设计

一.外键约束 保证数据的完整性. 定义外键约束: 可以直接在create语句中定义外键 foreign key 当前表名(字段名) references 目标表名(目标表的主键) 创建完语句后,可以直接使用修改语句定义 alter table 表名 add foreign key 当前表名 (字段名) references 目标表名(目标表的主键) 二.多表设计的三种实体关系 多对多.一对多和一对一 三.多表设计之---------一对多 一个班级可以有多个学生,但是一个学生只能属于一个班级.或

php不用递归完成无限分类,从表设计入手完整演示过程

无限分类是什么就不废话了,可以用递归实现,但是递归从数据库取东西用递归效率偏低,如果从表设计入手,就很容易做到网站导航的实现,下面是某论坛导航,如下图 网上无限分类大多不全面,今天我会从设计表开始, 首先我们先做视图界面, <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>白超华-博客园</title> &

mysql中的索引原理与表设计

索引是有效使用数据库的基础,但你的数据量很小的时候,或许通过扫描整表来存取数据的性能还能接受,但当数据量极大时,当访问量极大时,就一定需要通过索引的辅助才能有效地存取数据.一般索引建立的好坏是性能好坏的成功关键. 1.InnoDb数据与索引存储细节 使用InnoDb作为数据引擎的Mysql和有聚集索引的SqlServer的数据存储结构有点类似,虽然在物理层面,他们都存储在Page上,但在逻辑上面,我们可以把数据分为三块:数据区域,索引区域,主键区域,他们通过主键的值作为关联,配合工作.默认配置下