批量获取DataGrid控件模板列中的数据

原创 2005年03月03日 15:30:00

批量获取DataGrid控件模板列中的数据

在DataGrid中一般只能单个获取每一行的数据,若要批量获取DataGrid控件中的数据必须对每一个模板列的控件进行扫描,获取其中的数据。
我本想做的程序是根据不同的行数,由用户一次输入若干数据,提交后系统自动获取批量数据的程序。
以下程序简单表达了需要实现的功能

test.aspx

..........

<asp:DataGrid id="dgResult" runat="server" BorderColor="#DEBA84" BorderStyle="None" CellSpacing="2"
                 BorderWidth="1px" BackColor="#DEBA84" CellPadding="3" AutoGenerateColumns="False">
                 <FooterStyle ForeColor="#8C4510" BackColor="#F7DFB5"></FooterStyle>
                 <SelectedItemStyle Font-Bold="True" ForeColor="White" BackColor="#738A9C"></SelectedItemStyle>
                 <ItemStyle ForeColor="#8C4510" BackColor="#FFF7E7"></ItemStyle>
                 <HeaderStyle Font-Bold="True" ForeColor="White" BackColor="#A55129"></HeaderStyle>
                 <Columns>
                  <asp:BoundColumn DataField="id" HeaderText="列号"></asp:BoundColumn>
                  <asp:TemplateColumn HeaderText="列名">
                   <ItemTemplate>
                    <asp:TextBox Runat="server" Enabled="True" Width="50" ID="col"></asp:TextBox>
                   </ItemTemplate>
                  </asp:TemplateColumn>
                  <asp:TemplateColumn HeaderText="整数精度">
                   <ItemTemplate>
                    <asp:TextBox Runat="server" Enabled="True" ID="Textbox1" Width="50">20</asp:TextBox>
                   </ItemTemplate>
                  </asp:TemplateColumn>
                  <asp:TemplateColumn HeaderText="小数点精度">
                   <ItemTemplate>
                    <asp:TextBox Runat="server" Enabled="True" ID="Textbox2" Width="50">10</asp:TextBox>
                   </ItemTemplate>
                  </asp:TemplateColumn>
                 </Columns>
                 <PagerStyle HorizontalAlign="Center" ForeColor="#8C4510" Mode="NumericPages"></PagerStyle>
       

         </asp:DataGrid>
<asp:Button id="btnOK" runat="server" Text="提交"></asp:Button>
......
            

test.aspx.cs


private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   if(!IsPostBack)
                mfbind(DataSource());
  }

  private IList DataSource()
  {
   DataTable dt=new DataTable();
   DataColumn dc=new DataColumn();
   dc.ColumnName="id";
   dc.DataType=System.Type.GetType("System.Int32");
   dc.ReadOnly=true;
   dc.Unique=true;
   dc.AutoIncrement=true;
   dc.AutoIncrementSeed=0;
   dc.AutoIncrementStep=1;
   dt.Columns.Add(dc);

   dc=new DataColumn();
   dc.ColumnName="列名称";
   dc.DataType=System.Type.GetType("System.String");
   dt.Columns.Add(dc); 
  
   for(int i=0;i<10;i++)
   {    
    DataRow dr=dt.NewRow();
    dr[1]=i;    
    dt.Rows.Add(dr);
   }
   Session["Source"] = dt;
   return dt.DefaultView;
  }
  private void mfbind(IList dv)
  {   
   this.dgResult.DataSource=(DataView)dv;
   this.dgResult.DataBind();
  }
private void btnOK_Click(object sender, System.EventArgs e)
  {
   //string tmpa=dgResult__ctl2_col1.Text;
   TextBox txt;
   ArrayList mArr=new ArrayList();   
   for(int i=0;i<10;i++)
   {
    txt=new TextBox();
    txt=(TextBox)dgResult.Items[i].FindControl("col");
    mArr.Add(txt.Text);
   }
   for(int i=0;i<mArr.Count;i++)
                this.lblProblem.Text+=mArr[i].ToString()+" ; ";
   
  
  }

其实这样的程序有共通性,通过DataGrid控件可以对数据进行批量处理,特别是对删除数据等操作的过程中使用起来及其方便快捷,只要将程序的模板列中的TextBox控件改为CheckBox控件或者DropDownList控件,扫描所有的子控件就可以实现对数据的批量快速删除、修改等操作。

DataGrid模板列自定义控件

  • 2014年12月24日 10:37
  • 60KB
  • 下载

WPF DataGridTemplateColumn 获取内部控件

xaml前台代码:                                                                               ...
  • m15188153014
  • m15188153014
  • 2015-09-21 16:04:13
  • 911

Asp.Net中DataGrid的模版列(TemplateColumn)内容控制简单方法。

最近写了几个asp.net的项目。其中,Asp.Net的控件DataGrid使用的最多了,前几天需要一个功能,我研究了很长时间,发现一个方法,应该是最简单的实现。现表述如下。 DataGrid的htm...
  • TomMax
  • TomMax
  • 2004-12-16 19:40:00
  • 3243

编写 WPF DataGrid 列模板,实现更好的用户体验

DatePicker 和新的 DataGrid 行 用户与 DataGrid 中日期列的交互给我造成了很大的麻烦。 我通过将一个 Data Source 对象拖动到 WPF 窗口上,创建了一个...
  • wangyong0921
  • wangyong0921
  • 2011-11-29 11:31:17
  • 5317

《EasyUI + MVC + EF +WCF》——实现对Datagrid中数据的批量修改或保存

这两天在干组织部项目的时候,用到了EasyUI的可编辑表格,这时候用户在保存,修改信息的时候变得方便多了,因为这样可以直接在表格中更改数据,不用再选中数据后然后点击编辑,最后弹出一个部分视图来,将待修...
  • u013067402
  • u013067402
  • 2016-03-01 10:23:21
  • 1649

DataGridTemplateColumn 如何获取内部控件

WPF中有时候我们不使用DataGridTextColumn 而使用用途更加宽广的DataGridTemplateColumn  但是用途多的东西当然也更复杂。 这里说下如何取DataGr...
  • norsd
  • norsd
  • 2013-09-04 17:52:54
  • 6070

dorado DataGrid选择列功能

前段时间要实现一个datagrid选择列的功能,想了很多办法,还好在dorado文档查到dataColumn控制headerRenderer属性,那好办就在列头中加一个复选框。 ckeckBox也添加...
  • junjun222222
  • junjun222222
  • 2017-09-26 10:57:49
  • 235

WPF中DataGrid使用自定义列绑定数据

WPF中DataGrid使用自定义列绑定数据
  • hit_why
  • hit_why
  • 2017-03-24 14:24:35
  • 3720

easyui-datagrid获取行和列数据

1、获取当前行var row = $('#dg').datagrid('getSelected');2、获取所有选中行var rows = $('#dg').datagrid('getSelectio...
  • tiana0
  • tiana0
  • 2017-01-14 17:26:49
  • 15559

怎么触发DataGrid模板列中控件的事件

在DataGrid模板列中的按钮可以触发ItemCommand事件但是怎么触发其他事件?(比如放置DropDownList怎么触发SelectedIndexChange事件?……)在模板列中增加一个D...
  • jelink
  • jelink
  • 2006-08-25 16:33:00
  • 955
收藏助手
不良信息举报
您举报文章:批量获取DataGrid控件模板列中的数据
举报原因:
原因补充:

(最多只允许输入30个字)