GridView的DataKeyNames属性 转载的

news/2024/7/5 6:02:22

偶今天用到这个了,转载  "事在人为"楼主的,原文地址: http://www.cnblogs.com/andhm/archive/2010/05/07/1730024.html

 

DataKeyNames表示主键的列名,可以通过GridViewEntity.DataKeys[RowIndex]["ColumsName"]来获取他的值,当然它是不会显示出来的,其实我是在一个用SqlDataSource中发现的,看到了有这么一个主键而实现更新,当然在我们多层开发中也不能缺少这个。当我们在用Template时怎么取得值呢?我们可以把那个列也设为DataKeyNames中,记得多个要用","隔开。
如果没有设置成DataKeyNames,那只能通过GridViewEntity.Rows[RowIndex].Cell[Index].Text来得到值了,不知老兄有没有看到一些HTML字符呢? 这个最是经常见得了,不用当心我们可以用HttpUnility.HtmlDecode()来解决他!

 

 

在我们使用GridView的过程中,经常会遇到这样对问题,我们选择某一行进行编辑,或选择某一行删除或者.......时,我们需要获取当前行的某些信息,尤其是当前行的主键信息,主键信息一般不显示在页面,此时我们有三种方法来处理。 第一种是使用DataKeyNames ,这里要重点介绍的。 第二种是使用按钮的CommandArgument属性邦定需要的信息。 第三种是最古老最通用的方法使用隐藏的方法显示。

第一种方法:使用DataKeyNames,DataKeyNames可邦定一列,也可邦定多列 前台:DataKeyNames="FID"   绑定一个值 后台:GridView1.DataKeys[e.Row.RowIndex].Value.ToString();

前台:DataKeyNames="FID,FName"   绑定两个值 后台:GridView1.DataKeys[e.Row.RowIndex].Values[0].ToString(); 后台:GridView1.DataKeys[e.Row.RowIndex].Values[1].ToString(); 或者 后台:GridView1.DataKeys[e.Row.RowIndex].Values["FID"].ToString(); 后台:GridView1.DataKeys[e.Row.RowIndex].Values["FName"].ToString();

第二种方法:是用按钮的CommandArgument属性邦定需要的信息。

典型的例子:下载附件列(有附件的显示下载链接,无附件的显示为空) <asp:TemplateColumn HeaderText="附件"> <HeaderStyle Width="7%"></HeaderStyle> <ItemTemplate> <asp:LinkButton id="LinkButton1" CommandName="download" CommandArgument='<%# DataBinder.Eval(Container.DataItem, "attached_file")%>' runat="server" Visible='<%# ((DataBinder.Eval(Container.DataItem, "attached_file").ToString()) != "") %>'>下载</asp:LinkButton> </ItemTemplate> </asp:TemplateColumn>

在dgHKStock_ItemCommand事件中: if ("download" == e.CommandName) {     mybc.SystemOverTime0();          // 判断Session是否过期     mybc.RightManage("16010500");    // 判断用户是否有打开此网页的权限     mybc.HTTP_DownloadFile(e.CommandArgument.ToString()); // 取得当前存货信息的附件存放路径

}

 

最古老最通用的方法使用隐藏的方法显示。

<style type="text/css">     .test{         display:none;     }     </style>

<asp:TemplateField HeaderText="姓名" SortExpression="name" ItemStyle-CssClass="test" HeaderStyle-CssClass="test"> <ItemTemplate>     <asp:Label ID="Label1" runat="server" Text='<%# Eval("name") %>' ></asp:Label>     </ItemTemplate>    </asp:TemplateField>

 

把隐藏列转成模版列,通过FindControl访问模版列的内容:

<asp:TemplateField Visible="false">                 <ItemTemplate>                 <asp:Label runat="server" Text='<%#Eval("id") %>' ID="lblId"></asp:Label>                 </ItemTemplate> </asp:TemplateField>

 

protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)     {         Label lblId=GridView1.Rows[e.NewEditIndex].Cells[0].FindControl("lblId") as Label;         Response.Write(lblId.Text);     }

转载于:https://www.cnblogs.com/ry123/archive/2012/06/13/2547882.html


http://lihuaxi.xjx100.cn/news/252332.html

相关文章

RH5.4下samba共享配置实例(3)

一、基于用户名的访问控制实例&#xff1a; 王乾大哥写的比较详细了&#xff0c;我是跟着他的教程学习的&#xff0c;按照他的教程走一边&#xff1b; 要求如下&#xff1a; 1、创建一个公共的交换文件夹&#xff0c;所有人都可以写入删除&#xff0c;但不能删除修改其他人的文…

2013高教社杯---B碎纸片的拼接复原

破碎文件的拼接在司法物证复原、历史文献修复以及军事情报获取等领域都有着重要的应用。传统上&#xff0c;拼接复原工作需由人工完成&#xff0c;准确率较高&#xff0c;但效率很低。特别是当碎片数量巨大&#xff0c;人工拼接很难在短时间内完成任务。随着计算机技术的发展&a…

Datawhale组队学习周报(第031周)

文章目录即将结营的开源内容正在进行的开源内容Datawhale打磨课01 计算机视觉02 自然语言处理之情感分析03 基于transformers的自然语言处理(NLP)入门04 机器学习的数学基础05 青少年编程&#xff08;Scratch 二级&#xff09;Datawhale精品课[01 吃瓜教程——西瓜书南瓜书](ht…

《Adobe Premiere Pro CC经典教程(彩色版)》——2.2 建立项目

本节书摘来自异步社区《Adobe Premiere Pro CC经典教程&#xff08;彩色版&#xff09;》一书中的第2课&#xff0c;第2.2节&#xff0c;作者 【英国】Maxim Jago&#xff08;马克西姆 亚戈&#xff09;&#xff0c;译者 陈昕昕&#xff0c;郭光伟 &#xff0c;更多章节内容可以…

正确设置php-fpm和nginx防止网站被黑

2019独角兽企业重金招聘Python工程师标准>>> 核心总结&#xff1a;php-fpm 子进程所使用的用户&#xff0c;不能是网站文件所有者。 凡是违背这个原则&#xff0c;则不符合最小权限原则。 根据生产环境不断反馈&#xff0c;发现不断有 php网站被挂木马&#xff0c;绝…

WAVE SUMMIT+2022明日开场,六大看点不容错过!

在2022年最后一个乐章奏响之前&#xff0c;WAVE SUMMIT第八届峰会将率先拉开帷幕。11月30日&#xff0c;由深度学习技术及应用国家工程研究中心主办、百度飞桨承办的WAVE SUMMIT2022深度学习开发者峰会将以网上直播的方式呈现。明日14点&#xff0c;冬日AI盛会WAVE SUMMIT2022将…

Spring AOP无法拦截内部方法调用-- expose-proxy=true用法

假设一个接口里面有两个方法&#xff1a; package demo.long;public interface CustomerService { public void doSomething1(); public void doSomething2(); } 接口实现类如下&#xff1a; package demo.long.impl;import demo.long.CustomerService; public class Custo…

【MATLAB】find 函数 总结

【MATLAB版本为2014a】 MATLAB中函数find函数的作用是进行矩阵元素的查找&#xff0c;它通常与关系函数和逻辑运算相结合。 indfind(X,...)&#xff1a;该函数查找矩阵中的非零元素&#xff0c;函数返回这些元素的双下标[row,col]find(X,...)&#xff1a;该函数查找矩阵X中的…