说明:近来看到不少人想在DataGrid、GridView 使用比较灵活的方式来编辑、查看、删除其中的数据选项(当然它们本身也内置了这些功能),却苦于找不到比较好的办法,本人结合实际代码说明一下如何使用LinkButton来实现上述功能。
--------------------------------------------GridViewLinkButton.aspx-----------------------------------------

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="GridViewLinkButton.aspx.cs" Inherits="GridViewLinkButton" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>无标题页</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="gvPersonList" runat="server" AutoGenerateColumns="False">
            <Columns>
                <asp:BoundField DataField="Id" HeaderText="编号" />
                <asp:BoundField DataField="Name" HeaderText="姓名" />
                <asp:TemplateField HeaderText="性别">
                    <ItemTemplate>
                        <%# Eval("Sex").ToString()=="true"?"男":"女" %>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:BoundField DataField="Age" HeaderText="年龄" />
                <asp:TemplateField HeaderText="婚否">
                    <ItemTemplate>
                        <%# Boolean.Parse(Eval("Married").ToString())==true?"是":"否" %>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField HeaderText="婚否">
                    <ItemTemplate>
                        <asp:LinkButton CommandArgument='<%# Eval("Id") %>' Enabled='<%# Boolean.Parse(Eval("Married").ToString())==true?false:true %>' Text="设为结婚" runat="server" OnCommand="SetMarried"></asp:LinkButton>
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>
   
    </div>
    </form>
</body>
</html>
--------------------------------------GridViewLinkButton.aspx.cs------------------------------------------------
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class GridViewLinkButton : System.Web.UI.Page
{
    private string firstName = "赵钱孙李周吴郑王冯陈诸卫蒋沈韩杨朱秦尤许何吕施张孔曹严华";
    private string lastName="猛勇刚强豹彪雁燕蓉菲";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            BindGridView();
        }
    }
private void BindGridView()
    {
        DataTable myData = CreateDataTable();
        Session["MyData"] = myData;
        gvPersonList.DataSource = myData;
        gvPersonList.DataBind();
    }
    //手动生成DataTable
    private DataTable CreateDataTable()
    {
        DataTable data = new DataTable();
        DataColumn dcId = new DataColumn("ID", typeof(Int32));
        dcId.AutoIncrement = true;
        dcId.AutoIncrementSeed = 1;
        dcId.AutoIncrementStep = 1;
        data.Columns.Add(dcId);
        data.Columns.Add(new DataColumn("Name",typeof(string)));
        data.Columns.Add(new DataColumn("Age",typeof(int)));
        data.Columns.Add(new DataColumn("Sex",typeof(bool)));
        data.Columns.Add(new DataColumn("Married",typeof(bool)));
        DataRow dataRow = null;
        Random random = new Random();
        for (int i = 0; i < 20; i++)
        {
            dataRow = data.NewRow();
            //随机生成姓名
            dataRow["Name"] = firstName.Substring(random.Next(firstName.Length), 1) + lastName.Substring(random.Next(lastName.Length), 1);
            //随即生成介于20至100之间的年龄
            int age = random.Next(20, 100);
            dataRow["Age"] = age;
            //随即设置性别
            bool sex = (random.Next(100) % 2 == 0) ? true : false;
            dataRow["Sex"] = sex;
            if (((sex == true) && (age >= 22)) || ((sex == false) && (age >= 20)))//男性结婚年龄大于22周岁,女性结婚年龄大于20周岁
            {
                dataRow["Married"] = (random.Next(500) % 2 == 0) ? true : false;
            }
            else
            {
                dataRow["Married"] = false;
            }
            data.Rows.Add(dataRow);
        }
        return data;
    }
    //LinkButton的OnCommand事件的处理方法
    public void SetMarried(Object sender, CommandEventArgs e)
    {
        e.CommandArgument.ToString();
        DataTable data = Session["MyData"] as DataTable;
        for (int i = 0; i < data.Rows.Count; i++)
        {
            if (data.Rows[i]["Id"].ToString() == e.CommandArgument.ToString())
            {
                data.Rows[i]["Married"] = true;
                break;
            }
        }
        gvPersonList.DataSource = data;
        gvPersonList.DataBind();
    }
}
-----------------------------------运行结果-----------------------------------------------------------------
可以看见,一旦某个人是已婚,则不能再设置为已婚状态了。
下图是将某些未婚人士设置成已婚后的截图。
 

GridView中妙用LinkButton相关推荐

  1. [学习]GridView 学习集合 -- GridView中使用超链接的技巧

    GridView中使用超链接的技巧 数据绑定方式有两种,如下示例: Eval方式 <%# Eval("id") %> Bind方式 <%# Bind(" ...

  2. Gridview导出到Excel,Gridview中的各类控件,Gridview中删除记录的处理

    Asp.net 2.0中新增的gridview控件,是十分强大的数据展示控件,在前面的系列文章里,分别展示了其中很多的基本用法和技巧(详见< ASP.NET 2.0中Gridview控件高级技巧 ...

  3. 在GridView中针对鼠标单击的某一独立单元格进行编辑

    原文地址: http://www.codeproject.com/KB/webforms/EditGridviewCells.aspx [原文源码下载] [译者改后源码下载] 作者:Declan Br ...

  4. 在GridView中添加按钮后,如何触发按钮的各种事件?

    //在GridView中添加按钮后,如何触发按钮的各种事件? 1.在GridView的"编辑列"属性窗口中,增加新的Botton列. 2.然后再该窗口右边属性中,将外观项下的But ...

  5. 获取GridView中RowCommand的当前选中行的索引或主键Id

    获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个LinkButton 前台 (如果在后台代码中用e.CommandArgument取值的话前台代码就必须在按钮中设 ...

  6. GridView 中添加删除确认提示框

    在GridView中我们可以直接添加一个CommandField删除列来删除某行信息.但为了避免误操作引起的误删除,在删除操作者让操作者再确认下,完后再进行删除. 首先我们给我们的GridView 添 ...

  7. GridView 中 Bind和Eval的区别详解

    Eval()方法在运行时使用反射执行后期绑定计算,因此与标准的ASP.NET数据绑定方法bind相比,会导致性能明显下降.它一般用在绑定时需要格式化字符串的情况下.多数情况尽量少用此方法 Eval 方 ...

  8. 获取GridView中RowCommand的当前索引行

    获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个Button <asp:TemplateField HeaderText="测试"> ...

  9. DataGrid与GridView中删除前提示框与编辑框长度设置的实现(ASP.NET)

    实现删除数据前弹出询问提示框主要有四中方法: 一.在.aspx或.ascx文件中增加客户端JS脚本: 把下面的代码直接加到.aspx或.ascx文件中即可,注意其中的"删除"二字根 ...

最新文章

  1. linux系统下源码安装mysql5.6数据库
  2. leetcode-寻找两个正序数组的中位数
  3. 记录本地Hexo博客部署到服务器上
  4. 在Linux系统的命令行中为MySQL创建用户的方法
  5. 题解 P5301 【[GXOI/GZOI2019]宝牌一大堆】
  6. Callgrind:调用图生成缓存和分支预测分析器
  7. SUN:开源在Web2.0时代
  8. windows netstat命令小节
  9. opencv之调取摄像头拍照
  10. 根据日期算星座 mysql_php根据日期获取星座
  11. 火狐浏览器设置关闭提醒
  12. 导弹防御系统(LIS)
  13. 计算机网络中OUI是什么意思,抓包出现oui Unknown是什么意思,请各位高手指教!!
  14. 常用的表格正则验证 + 省份选择 JS JQ
  15. win10查看计算机硬件配置,怎么看电脑配置,详细教您win10怎么看电脑配置
  16. 转折点:移动互联网时代的商业法则
  17. 有向无环图的拓扑排序 关键路径
  18. 3D游戏建模布线方法
  19. MySQL~数据库表中数据的增删查改(基础篇)
  20. RCE _通达 OA -2020HW

热门文章

  1. 几何画板手机版_运用几何画板解决动点最值问题(二)
  2. ncverilog脚本_NC-Verilog仿真详解
  3. JAVA awt eventqueue_线程“AWT-EventQueue-1”中的异常java.lang.NullPointerException
  4. JAVA不同类型数组重载_java学习笔记--java中的方法与数组
  5. uva oj 567 - Risk(Floyd算法)
  6. mount --bind的用处
  7. (三)linux之根文件系统的制作
  8. aix升级新安装oracle,AIX 5L上安装和升级Oracle
  9. 查询分析300万笔记录_给你100万条数据的一张表,你将如何查询优化?
  10. java 极客_Java极客思维