网络编程 
首页 > 网络编程 > 浏览文章

DataGridView中绑定DataTable数据及相关操作实现代码

(编辑:jimmy 日期: 2024/9/17 浏览:3 次 )
复制代码 代码如下:
DataTable DT = new DataTable();
DT.Columns.Add("Name");
DT.Columns.Add("Sex");
DataRow dr = DT.NewRow();
dr[0] = "Kenny";
dr[1] = "男";
DT.Rows.Add(dr);

A:在DataGridView控件的列编辑中将DataPropertyName属性设为DataTable的列名称,如:DataPropertyName="Name";
B:选中行操作:
复制代码 代码如下:
private void dataGridView_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
if (e.ColumnIndex == 0 && e.RowIndex != -1 && !dataGridView.Rows[e.RowIndex].IsNewRow)
{
String name = dataGridView.Rows[e.RowIndex].Cells["dataGridViewTextBoxColumn1"].Value.ToString();
MessageBox.Show(name);
}
}

e.ColumnIndex指的是你所点击的列的索引,e.RowIndex是行的索引,如果dataGridView没有数据,则e.RowIndex为-1,Cells["dataGridViewTextBoxColumn1"]指的是dataGridView中给列起的名字,也可以用索引表示,写成Cells[0],即第1列.
如果是在web页面的GridView中,需要在GridView要取得值的标签里加入CommandArgument="<%#((GridViewRow)Container).RowIndex %>",并指定CommandName, 通过GridView的FindControl来找到控件,获取控件的值.
代码如下:
asp页面:
复制代码 代码如下:
<asp:LinkButton ID="lkSelect" runat="server" CommandName="Select" CommandArgument="<%#((GridViewRow)Container).RowIndex %>">查看截图</asp:LinkButton>

后台:
在GridView的RowCommand事件里写如下代码:
复制代码 代码如下:
protected void GridView_RowCommand(object sender, GridViewCommandEventArgs e)
{
if (e.CommandName == "Select")
{
int index = Convert.ToInt32(e.CommandArgument); //行索引
GridViewRow row = this.GridView.Rows[index]; //获得GridViewRow的一行
Label label1 = (Label)row.FindControl("label1");
String name = label1.Text;
Response.Write(name);
}
}
上一篇:asp.net Linq TO Sql 分页方法
下一篇:一天精通asp.net的学习经验小结
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 SiteMap