ASPxGridView动态创建表格列编辑模板

时间:2021-09-05 22:48:05

在项目中用到了DevExpress的ASPxGridview控件,每每去配置它的时候,总感觉很是啰嗦,于是想到了用代码自动配置。

于是有了这样的代码:

             foreach (ZiyuWeb.Entity.Sys_UIConfig item in sConfigs)
{
switch (item.ControlName)
{
case "ASPxDropDown_ASPxCheckListBox":
{
DevExpress.Web.ASPxGridView.GridViewDataDropDownEditColumn col = new GridViewDataDropDownEditColumn();//创建一个表格列;
col.FieldName = item.FieldName;//表格列绑定的数据源字段名称
col.Caption = item.FieldDescribe;//字段显示标题
col.Name = "col_" + item.FieldName;//列名称
col.VisibleIndex = item.OrderByID;//显示顺序
col.Width = item.Width;//显示宽度
col.Visible = item.UserIsVisible;//是否可见
col.ReadOnly = item.UserReadOnly;//是否只读
// col.EditItemTemplate = new ZiyuWeb.ASPxCheckListBox_DropDownTemplate("", item.QueryStr, col.Name);//创建该字段的编辑模板,如果是标准的DevExpress.Web.ASPxEditor则无需创建编辑模板了。但若是DropDown或者自己写的控件,就必须自行创建了。
mygridview.Columns.Add(col);//添加到View; break;
}
……
}
}

  有了上面代码创建的表格,则ASPxGridview控件只需要设置一下配置文件名称和数据源,便可以以一行代码来完美展现了。

ZiyuWeb.WebFunc.ZiyuDevHelper.configGridView(ASPxGridView1, "Sys_UIConfig", true, null);

创建EditItemTemplate。

    class MyTemplate_AspxCheckBoxList : ITemplate
{
int _iwidth = 80;
public int Iwidth
{
get { return _iwidth; }
set { _iwidth = value; }
}
ZiyuWeb.Entity.Sys_UIConfig uiconfig;
public MyTemplate_AspxCheckBoxList(ZiyuWeb.Entity.Sys_UIConfig myuiconfig)
{
uiconfig = myuiconfig;
Iwidth = uiconfig.Width; }
public void InstantiateIn(Control container)
{
DevExpress.Web.ASPxEditors.ASPxCheckBoxList alistbox = new ASPxCheckBoxList();
alistbox.TextField = uiconfig.FieldName;
alistbox.ValueField = uiconfig.FieldName;
if (uiconfig.QueryStr != null)
{
if (uiconfig.QueryStr.Length > 0)
{
if (uiconfig.QueryStr.IndexOf("select") >= 0)
{
System.Collections.ArrayList alist = MyHelper4Web.MyStringHelper.getTableNamefromSql(uiconfig.QueryStr);
XCode.DataAccessLayer.DAL mydal = XCode.DataAccessLayer.DAL.Create("common");
System.Data.DataTable dt = mydal.Select(uiconfig.QueryStr, alist[0].ToString()).Tables[0];
if (dt.Columns.Count == 1)
{
for (int i = 0; i < dt.Rows.Count; i++)
{
alistbox.Items.Add(dt.Rows[i][0].ToString());
}
}
}
else
{
System.Collections.ArrayList alist =
MyHelper4Web.MyConvertHelper.ConvertStringToArrayList(uiconfig.QueryStr, ";");
for (int i = 0; i < alist.Count; i++)
{
alistbox.Items.Add(alist[i].ToString());
}
}
}
}
alistbox.ID = "myCon_" + uiconfig.FieldName;
alistbox.ClientInstanceName = "myCon_" + uiconfig.FieldName;
alistbox.RepeatColumns = 3;
alistbox.TextWrap = false;
alistbox.RepeatDirection = RepeatDirection.Horizontal;
alistbox.RepeatLayout = RepeatLayout.Flow; string rowValue = (container as GridViewEditItemTemplateContainer).Text;
string[] rowValueItems = rowValue.Split(';');
List<string> rowValueItemsAsList = new List<string>();
rowValueItemsAsList.AddRange(rowValueItems);
foreach (ListEditItem item in alistbox.Items)
if (rowValueItemsAsList.Contains(item.Value.ToString()))
item.Selected = true;
container.Controls.Add(alistbox);
}
}

  

ASPxGridView动态创建表格列编辑模板的更多相关文章

  1. FineUIMvc随笔 - 动态创建表格列

    声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. 用户需求 用户希望实现动态创建表格列,在 WebForms 中,我们通过在 Page_Init 中创建列来实现: 但是在 MVC ...

  2. FineUIMvc随笔(1)动态创建表格列

    声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. <FineUIMvc随笔>目录 FineUIMvc随笔(1)动态创建表格列 FineUIMvc随笔(2)怎样在控件中 ...

  3. js&sol;jq动态创建表格的行与列

    之前做了一个项目,需求是能动态创建表格行,动态创建表格的列,度了很多资料,都没有动态创建列的插件,所以自己动手写了一个 需求大概是(下图) 1.动态添加一行.2.动态添加一列,3.删除行.4.删除列, ...

  4. javascript动态创建表格:新增、删除行和列

    转载:http://www.cnblogs.com/pato/archive/2009/09/02/1559068.html 利用js来动态创建表格有两种格式,appendChild()和insert ...

  5. js动态创建表格&comma;删除行列的小例子

    js动态创建表格,删除行列的实例代码. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...

  6. jquery动态创建表格

    1.代码实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  7. 利用javascript动态创建表格

    //说明:实现功能.原理上文相同.不过这次是利用已有的简单的方法创建行和列,并实现内容行鼠标移入变色功能! 效果图: /*两个方法 1.  trNode  table.insertRow(-1)    ...

  8. js如何动态创建表格(两种方法)

    js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...

  9. 第84天:jQuery动态创建表格

    jQuery动态创建表格 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

随机推荐

  1. AndroidStudio 混淆打包

    AndroidStudio中的项目可以用compile的形式引入github上的开 源项目,可以引用module,而不一定都要用libs文件夹中添加jar包的形式.在最终realease打包时,混淆的 ...

  2. mac book air 装win7

    1. 使用mac book air A1465中 bootCamp制作启动U盘: 需要U盘一个8G,windows 7 原版镜像ISO安装文件一个,根据bootcamp操作提示选择文件及U盘, 注意U ...

  3. 小记css的margin collapsing

    近期在做web页面设计的时候,莫名的发现最上面会出现一个横条,颜色为html的背景颜色.本意是那一片空横条应该为header的背景色.查了一些资料,发现是margin collapsing的问题,记录 ...

  4. 16&period;ajax&lowbar;case02

    # 抓取当当网书评 # http://product.dangdang.com/25340451.html import json import requests from lxml import e ...

  5. Bridge &lpar;br0&rpar; Network on Linux

    动手实践虚拟网络 - 每天5分钟玩转 OpenStack(10) - CloudMan - 博客园https://www.cnblogs.com/CloudMan6/p/5296573.html li ...

  6. IntelliJ IDEA 性能优化

    idea打开的多了 内存占用也就多了 下边是亲试的优化ide性能的方法 1.设置JVM的启动参数: 进入idea的安装目录的bin文件夹 打开 idea.exe.vmoptions 文件, 修改-Xm ...

  7. Unity shader学习之Blinn-Phong光照模型

    Blinn-Phong光照模型不用计算反射方向,计算公式如下: h = normalize(v + l); Cspecular = Clight * mspecular * pow(max(0, do ...

  8. HDU - 1400 Mondriaan&&num;39&semi;s Dream

    HDU - 1400 思路: 轮廓线dp入门题 #include<bits/stdc++.h> using namespace std; #define fi first #define ...

  9. NotificationMangerService处理显示通知

    设置——>应用——>点击“已下载”列表中的任一APP,如图:  代码位置:Settings\src\com\android\settings\applications\InstalledA ...

  10. 20145118《Java程序设计》 第9周学习总结

    20145118 <Java程序设计>第9周学习总结 教材学习内容总结 1.SUN公司定义了一套Java操作数据库的规范(接口)来简化数据库操作,称之为JDBC.开发人员只需要学习jdbc ...