一、动态添加模板列:

1、建立模板列样式:

说明:下边代码可以直接写在aspx文件中,也可以单独建立cs文件;另外,我没有写button、linkButton等控件,意思差不多,不过当需要添加事件时,记得将事件名称传入,并附加在控件上

public class GridViewTemplate : ITemplate
{
/// <summary>
/// 模板类型:标题或内容;
/// DataControlRowType.Header和DataControlRowType.DataRow
/// </summary>
private DataControlRowType P_TemplateType;
/// <summary>
/// 列的名称:列标题时,为列显示名称;列内容时,为列的字段名称
/// </summary>
private string P_ColumnName;
/// <summary>
/// 列的类型:TextBox、DropDownList等
/// </summary>
private string P_ColumnType;

public GridViewTemplate()
{
//
//TODO: 在此处添加构造函数逻辑
//
}
/// <summary>
/// 构造函数:动态添加模版列
/// </summary>
/// <param name="TemplateType">模板类型:标题或内容;DataControlRowType.Header和DataControlRowType.DataRow</param>
/// <param name="ColumnName">列的名称:列标题时,为列显示名称;列内容时,为列的字段名称</param>
/// <param name="ColumnType">列的类型:列标题时,可为空;列内容时,为模板列的控件类型</param>
public GridViewTemplate(DataControlRowType TemplateType, string ColumnName, string ColumnType)
{
P_TemplateType = TemplateType;
P_ColumnName = ColumnName;
P_ColumnType = ColumnType;
}
public void InstantiateIn(System.Web.UI.Control container)
{
switch (P_TemplateType)
{
case DataControlRowType.Header://列标题
Literal lc = new Literal();
lc.Text = P_ColumnName;
container.Controls.Add(lc);
break;
case DataControlRowType.DataRow://模版列内容

if (P_ColumnType.ToUpper() == "TextBox".ToUpper())
{
TextBox tb = new TextBox();
tb.ID = "txt_" + P_ColumnName;
tb.AutoPostBack = true;
tb.EnableViewState = true;
//tb.Text = "";
tb.DataBinding += new EventHandler(tb_DataBinding);
container.Controls.Add(tb);
}
else if (P_ColumnType.ToUpper() == "Label".ToUpper())
{
System.Web.UI.WebControls.Label lb = new Label();
lb.ID = "lbl_" + P_ColumnName;
lb.EnableViewState = true;
//tb.Text = "";
lb.DataBinding += new EventHandler(lb_DataBinding);
container.Controls.Add(lb);
}
else
{ //默认为TextBox
TextBox tb = new TextBox();
tb.ID = "txt_" + P_ColumnName;
tb.AutoPostBack = true;
tb.EnableViewState = true;
tb.DataBinding += new EventHandler(tb_DataBinding);
container.Controls.Add(tb);
}

break;
default:
break;
}
}
void tb_DataBinding(object sender, EventArgs e)
{
TextBox txtdata = (TextBox)sender;
GridViewRow container = (GridViewRow)txtdata.NamingContainer;
object dataValue = DataBinder.Eval(container.DataItem, P_ColumnName);
if (dataValue != DBNull.Value)
{
txtdata.Text = dataValue.ToString();
}
}
void lb_DataBinding(object sender, EventArgs e)
{
Label lbldata = (Label)sender;
GridViewRow container = (GridViewRow)lbldata.NamingContainer;
object dataValue = DataBinder.Eval(container.DataItem, P_ColumnName);
if (dataValue != DBNull.Value)
{
lbldata.Text = dataValue.ToString();
}
}

}

2、前台aspx文件:

<asp:GridView ID="gvData" runat="server" SkinID="GridView" Width="100%" UseAccessibleHeader="False"
AutoGenerateColumns="False"  AllowPaging="True"
PageSize="100" onload="gvData_Load" >
<PagerSettings Visible="False" />
<HeaderStyle Font-Bold="True" />
</asp:GridView>

3、aspx.cs文件--创建GridView,并绑定数据:

说明:dt是外部获取的数据,我是根据数据表,动态生成GridView,并赋值

private void CreateDT(DataTable dt)
{

this.gvData.Columns.Clear();

TemplateField customField = new TemplateField();

for (int i = 0; i < dt.Columns.Count; i++)
{
customField = new TemplateField();
customField.ShowHeader = true;
customField.HeaderTemplate = new GridViewTemplate(DataControlRowType.Header, dt.Columns[i].ColumnName, "");
customField.ItemTemplate = new GridViewTemplate(DataControlRowType.DataRow, dt.Columns[i].ColumnName, "TextBox");
ViewState["txt_" + dt.Columns[i].ColumnName] = true;
gvData.Columns.Add(customField);
}

//绑定数据

this.gvData.DataSource = dt;
this.gvData.DataBind();

}

4、aspx.cs文件:重复建立并绑定数据,因为动态生成控件时,只要有刷新,所有的动态控件就全部消失,所以需要每次刷新都要重新绑定一次;

另外,我试过在OnInit、gvData_Init等事件中执行建立并绑定数据的操作,都可以实现,但是对于我不大适用,因为我是根据TreeView的选中项,来创建绑定GridView的;其他事件执行时机靠前,无法获取TreeView的选中项是哪个,而gvData_Load事件可以(虽然该事件也是在TreeView选中事件前执行,不过并不影响选中项的变化和获取到的内容)

protected void gvData_Load(object sender, EventArgs e)
{
DataTable dt=GetData();
CreateDT(dt);
}

5、aspx.cs文件:点击按钮,获取前台修改过的gvData中模板列的数据:

说明:我的保存时,先将数据保存进ViewState["DtData"]后,再执行保存功能;这么做是因为别的页面的问题,需要获取后,再刷新;不过大致意思都是相同的

注意:也可以使用TextBox txt= (TextBox)gvData.Rows[i].FindControl("txt_"+dtData.Columns[j].ColumnName);获取

private void SaveToTable()
{

DataTable dtData = (DataTable)ViewState["DtData"];
for (int i = 0; i < this.gvData.Rows.Count; i++)
{
for (int j = 0; j < dtData.Columns.Count; j++)
{

string txtName = "gvData$ctl" + (i + 2).ToString().PadLeft(2, '0') + "$txt_" + dtData.Columns[j].ColumnName;
if (Request.Form[txtName] != null)
{//目前仅能通过这个判断
dtData.Rows[i][j] = Request.Form[txtName];
JsService.ResponseMessage(this.UpdatePanel1, this.GetType(), "txtName:" + txtName + "----" + Request.Form[txtName]);
break;
}

}

}

ViewState["DtData"] = dtData;

}

6、实际上最主要的再gvData_Load事件中重复的动态创建并获取数据.

asp.net动态添加GridView的模板列,并获取列值的更多相关文章

  1. asp.net 动态添加自定义控件

    前两天一直纠结asp.net动态添加控件后,后台获取不到控件的问题,查看了网上很多的回答,可能自己的理解有误或者自己所掌握的知识有限,都没有解决我遇到的问题,经过两天的研究,终于把问题解决了. 我这里 ...

  2. ASP.NET动态添加用户控件的方法

    本文实例讲述了ASP.NET动态添加用户控件的方法.分享给大家供大家参考.具体实现方法如下: 为了让用户控件能ASP.NET页面实现动态添加,首先写一个接口IGetUCable,这个接口有一个函数,返 ...

  3. asp.net动态添加控件学习

    看了老师的教程后,自己一点感悟记录下来: 1.在页面提交后,动态生成的控件会丢失, 但如果生成控件的代码在pageload中,就可以,原理是每次生成页面都执行生成. 2.动态按件或页面原来控件, 在页 ...

  4. 根据Excel列类型获取列的值

    using System.Data; using System.IO; using System.Text; using System.Web; using NPOI.SS.UserModel; us ...

  5. ASP.NET给Table动态添加删除行,并且得到控件的值

    ASP.NET给Table动态添加控件并且得到控件的值 由于跟老师做一个小的项目,可是我自己又不太懂js,所以一直为动态建立表格并且能动态的取值和赋值感到苦恼.起初在网上找到了一些js资源,解决了动态 ...

  6. ASP申请单动态添加实现方法及代码

    一个申请单可以包含N个项目,添加申请单时就需要动态加入代码了. 动态Table表格 以下为引用的内容: <table border="0" width="98%&q ...

  7. asp.net 动态添加多个用户控件

    动态添加多个相同用户控件,并使每个用户控件获取不同的内容. 用户控件代码: 代码WebControls using System; using System.Collections.Generic;  ...

  8. .NET 后台动态添加GridView列

    BoundField bfColumn1 = new BoundField(); bfColumn1.DataField = "zbcompanyname"; bfColumn1. ...

  9. ASP.Net动态创建GridView

    1.创建Field BoundField requestitem = new BoundField();//注意Field可以是ButtonField,TemplateField,...等等GridV ...

随机推荐

  1. ASP.NET中@Page指令中的AutoEventWireup

    AutoEventWireup:指示控件的事件是否自动匹配 (Autowire).如果启用事件自动匹配,则为 true:否则为 false.默认值为 true.如果设为false,则事件不可用.有关更 ...

  2. HTML表单的问题

    1. 表单一定要放在<form>标签里面,就会有错误. 像<textarea>单独放的时候,单击的时候不会出现在开始位置,而是在任意单击的地方开始.  

  3. ASP.NET的学习之asp.net整体运行机制

    1.浏览器向服务器发送请求报文,服务器端的软件比如是IIS,接受请求 2.IIS通过aspnet_isapi.dll 这个程序集来请求FrameWork中的ASP.Net框架,这是对于集成模式 3.进 ...

  4. 一款jQuery满屏自适应焦点图切换特效

    一款jQuery满屏自适应焦点图切换特效 ,自适应当前浏览器的宽度,可以作为网站整个大背景的却换效果,很不错的一款不jquery特效. 兼容性没的说直接秒杀了IE6.适用浏览器:IE6.IE7.IE8 ...

  5. Sublime Text生成html标签快捷键

    Emmet Documentation Syntax   Child: > nav>ul>li <nav> <ul> <li></li> ...

  6. win7里开始菜单属性里的隐私项无法选择解决方法

    具体问题如下图,其中的隐私项目呈现灰色无法选择: 解决方法如下: win+R 输入gpedit.msc 回车,[用户配置][管理模板][开始菜单和任务栏],在右侧找到[关闭用户跟踪],双击进入设置界面 ...

  7. python杂记-4(迭代器&生成器)

    #!/usr/bin/env python# -*- coding: utf-8 -*-#1.迭代器&生成器#生成器#正确的方法是使用for循环,因为generator也是可迭代对象:g = ...

  8. python Django 学习笔记(六)—— 写一个简单blog做增删改练手

    简单效果图 1,创建一个项目myblog 可参考这里 myblog/ manage.py myblog/ __init__.py settings.py urls.py wsgi.py 2,创建blo ...

  9. 使用Telerik控件搭建Doubanfm频道部分

    今天感觉好累啊..还是坚持记录下. 收集的API: https://github.com/HakurouKen/douban.fm-api https://github.com/zonyitoo/do ...

  10. struct的成员对齐问题-结构体实际大小问题

    struct的成员对齐 注意:为了方便说明,等号左边是每个数据单独所占长度,右边是最终空间大小,以字节为单位. 一.什么时间存在对其问题:(32位机对齐方式是按照4字节对其的,以下所有试验都是在32位 ...