在实际应用中常可以看到数据展示控件有右键菜单的功能,对应的列标题也可以右键弹出快捷菜单设置指定列的显示与隐藏等功能。在我们的RDIFramework.NET Web框架中,只要是使用了EasyUI的DataGrid与TreeData控件我们已经做了扩展,所有datagrid与treegrid控件都自动拥有了列标题右键弹出快捷菜单设置指定列的显示与隐藏的功能。

  1、对于datagrid数据列表区域的右键弹出菜单只需要设置EasyUI的“onRowContextMenu”属性为:pageContextMenu.createDataGridContextMenu即可。

  2、对于treegrid数据列表区域的右键弹出菜单只需要设置EasyUI的“onContextMenu”属性为:pageContextMenu.createTreeGridContextMenu即可。

  后面会给出参考代码。下面就是两个右键菜单的展示效果。

  DataGrid参考Js代码如下:

$('#list').datagrid({
url: actionURL + 'GridPageListJson',
toolbar: '#toolbar',
title: "产品列表",
iconCls: 'icon16_table',
width: winSize.width,
height: winSize.height,
nowrap: false, //折行
rownumbers: true, //行号
striped: true, //隔行变色
idField: 'ID',//主键
singleSelect: true, //单选
sortName: 'CREATEON',
sortOrder: 'DESC',
onRowContextMenu: pageContextMenu.createDataGridContextMenu,
onDblClickRow:function(rowIndex, rowData){
document.getElementById('a_edit').click();
},
frozenColumns: [[
{ field: 'ck', checkbox: true },
{ title: '产品编码', field: 'PRODUCTCODE', width: 150 },
{ title: '产品名称', field: 'PRODUCTNAME', width: 300 }
]],
columns: [[
{ title: '主键', field: 'ID', width: 120, hidden: true },
{ title: '产品型号', field: 'PRODUCTMODEL', width: 150 },
{ title: '产品规格', field: 'PRODUCTSTANDARD', width: 75 },
{ title: '产品类别', field: 'PRODUCTCATEGORY', width: 70 },
{ title: '产品单位', field: 'PRODUCTUNIT', width: 63 },
{ title: '基准价', field: 'MIDDLERATE', width: 60 },
{ title: '基准系数', field: 'REFERENCECOEFFICIENT', width: 60 },
{ title: '单价', field: 'PRODUCTPRICE', width: 60 },
{ title: '批发价', field: 'WHOLESALEPRICE', width: 60 },
{ title: '促销价', field: 'PROMOTIONPRICE', width: 60 },
{ title: '内部价', field: 'INTERNALPRICE', width: 60 },
{ title: '特别价', field: 'SPECIALPRICE', width: 60 },
{
title: '作废标志', field: 'ENABLED', width: 56,
align: 'center',
formatter: function (v, d, i) {
return '<img src="../../Content/Styles/icon/bullet_' + (v ? "tick.png" : "minus.png") + '" />';
}
},
{ title: '产品描述', field: 'PRODUCTDESCRIPTION', width: 200 }
]],
pagination: true,
pageSize: 20,
pageList: [20, 10, 30, 50],
onLoadSuccess: function (data) {
var panel = $(this).datagrid('getPanel');
var tr = panel.find('div.datagrid-body tr');
refreshCellsStyle(tr);
var trHead = panel.find('div.datagrid-header tr');
trHead.each(function () {
var tds = $(this).children('td');
tds.each(function () {
$(this).find('span,div').css({ "font-size": "14px" });
});
});
}
});

  TreeGrid参考Js代码如下:

$('#organizeGrid').treegrid({
toolbar: '#toolbar',
width: winsize.width,
height: winsize.height,
nowrap: true,
rownumbers: true,
animate: true,
resizable: true,
collapsible: false,
onContextMenu: pageContextMenu.createTreeGridContextMenu,
url: '/FrameworkModules/OrganizeAdmin/GetOrganizeTreeJson',
idField: 'Id',
treeField: 'FullName',
onDblClickRow:function(row){
document.getElementById('btnEdit').click();
},
frozenColumns: [[
{ title: '名称', field: 'FullName', width: 200 },
{ title: '编码', field: 'Code', width: 100 }
]],
columns: [[
{ title: '简称', field: 'ShortName', width: 120 },
{ title: '主负责人', field: 'Manager', width: 70, align: 'center' },
{ title: '电话', field: 'OuterPhone', width: 100, align: 'center' },
{ title: '传真', field: 'Fax', width: 100, align: 'center' },
{ title: '有效', field: 'Enabled', width: 50, align: 'center', formatter: imgcheckbox },
{ title: '排序', field: 'SortCode', width: 80, align: 'center' },
{ title: '备注', field: 'Description', width: 300 }
]]
});

  

   相关文章列表:

   RDIFramework.NET — 基于.NET的快速信息化系统开发框架 — 系列目录

  一路走来数个年头,感谢RDIFramework.NET框架的支持者与使用者,大家可以通过下面的地址了解详情。

      RDIFramework.NET官方网站:http://www.rdiframework.net/

      RDIFramework.NET官方博客:http://blog.rdiframework.net/

同时需要说明的,以后的所有技术文章以官方网站为准,欢迎大家收藏!

RDIFramework.NET框架由专业团队长期打造、一直在更新、一直在升级,请放心使用!

       欢迎关注RDIFramework.net框架官方公众微信微信号:guosisoft),及时了解最新动态。

       扫描二维码立即关注

RDIFramework.NET框架Web中datagrid与treegrid控件自动生成右键菜单与列标题右键菜单的更多相关文章

  1. 在Web中如何使用Windows控件(ActiveX)[转]

    最近做的一个Web项目,需要在网页中播放摄像头采集的实时视频,我们已经有了播放视频的使用C#编写的windows控件,如何将其嵌入到网页中去了?这需要使用一种古老的技术,ActiveX. 1.将.Ne ...

  2. asp.net asp.net application 升级到 asp.net web 解决找不到控件 批量生成.designer文件

    颇费周折后,其实很简单,只需要生成designer文件后,重新保存所有页面即可.就是懒得写.懒真的是一种病,手上不能懒,脑子里更不能懒,否则就是给自己挖坑,仔细认真,注意细节!!!! PS:注意修改p ...

  3. 精通 WPF UI Virtualization (提升 OEA 框架中 TreeGrid 控件的性能)

    原文:精通 WPF UI Virtualization (提升 OEA 框架中 TreeGrid 控件的性能) 本篇博客主要说明如何使用 UI Virtualization(以下简称为 UIV) 来提 ...

  4. WEB网站类型系统中使用的OFFICE控件

    WEB下使用的OFFICE控件介绍,另提供一个原创破解首先来个名词解释,Office网络文档控件,就是在网页中编辑office文档的控件(前提是browser已经安装OFFICE).最近一个项目需要用 ...

  5. WEB网站类型系统中使用的OFFICE控件-破解Ntko-Office

    2011-12-12 22:49| 发布者: Admin| 查看: 1399| 评论: 0|原作者: 风云OA   摘要: WEB下使用的OFFICE控件介绍,另提供一个原创破解 首先来个名词解释,O ...

  6. 基于MVC4+EasyUI的Web开发框架经验总结(14)--自动生成图标样式文件和图标的选择操作

    在很多Web系统中,一般都可能提供一些图标的选择,方便配置按钮,菜单等界面元素的图标,从而是Web系统界面看起来更加美观和协调.但是在系统中一般内置的图标样式相对比较有限,而且硬编码写到样式表里面,这 ...

  7. Atitit. .net c# web 跟clientwinform 的ui控件结构比較

    Atitit. .net c# web 跟clientwinform 的ui控件结构比較 .net   4.5 webform Winform 命名空间 System.Web.UI.WebContro ...

  8. 在Winform开发框架中,利用DevExpress控件实现数据的快速录入和选择

    在实际的项目开发过程中,有好的控件或者功能模块,我都是想办法尽可能集成到我的WInform开发框架中,这样后面开发项目起来,就可以节省很多研究时间,并能重复使用,非常高效方便.在我很早之前的一篇博客& ...

  9. C/S模式开发中如何利用WebBrowser控件制作导航窗体

    原文:C/S模式开发中如何利用WebBrowser控件制作导航窗体 转自: CSDN 相信不少同学们都做过MIS系统的开发,今天这里不讨论B/S模式开发的问题.来谈谈winform开发.用过市面上常见 ...

随机推荐

  1. [数学]内接多边形求pi

  2. 函数图象(N=x+y*i)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  3. LinQ和ADO.Net增删改查 备忘

    是否些倦了 SqlConnection conn=new SqlConnection();一系列繁冗的代码? 来试试Linq吧 查: using System.Data.SqlClient; name ...

  4. bootstrap 使用需注意的一些点

    table 中td的宽度可以td 的style设置,然后在设置内部比如img对象款高实现对于 table其中某列的设置.

  5. [MySQL] Stored Procedures 【转载】

    Stored routines (procedures and functions) can be particularly useful in certain situations: When mu ...

  6. JS:call()和apply的区别

    每个函数都包含两个非继承而来的方法:call()和apply(); call()方法:参数,第一个是作用域中调用函数(this),其余是参数直接传给函数 扩大作用域,传递参数时,参数必须逐个列出. w ...

  7. asp.net三层架构详解

    一.数据库 /*==============================================================*/ /* DBMS name:      Microsof ...

  8. 设计模式-1-概要(c#版)

    最近又重新看了几本设计模式的书籍和文章,现在再看时又有了新的感悟,而这些书籍和文章都是从需求和业务场景讲什么业务可以用什么模式,要不就是纯理论不好理解,其实我们也要理解和佩服这些概括理论的大牛,必须让 ...

  9. *HDU3486 RMQ+二分

    Interviewe Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  10. Django入门1

    Django中的应用是以APP形式存在的,这是Django的主要特色. 入门--Hello,Django     在mysite中新建文件views.py,并在里面定义方法hello: 这里#-*- ...