zoukankan      html  css  js  c++  java
  • 2. 如何获取 GridView 编辑状态下单元格里的值?

    http://www.cnblogs.com/RChen/archive/2008/09/23/1296721.html
    还在使用这样的代码吗?

    var txtName = grid1.Rows[e.RowIndex].Cells[0].FindControl("txtName"as TextBox;
    if (txtName != null)
    {
        
    // 读取值
        
    // 
    }


    其实这些工作(在单元格中查找控件,并尝试获取其中的值)已经被封装了。现在,只要调用 ExtractValuesFromCell 方法即可。
    而该方法也被很多种列类型所支持:
    DataControlField, BoundField, AutoGeneratedField, CheckBoxField, ImageField, TemplateField, DynamicField

    你可以在 GridView 的 RowUpdating, RowDeleting 等事件中使用它。利用该方法,可以将值提取到所需的字典里去,然后再从字典中读取。这些字典包括:e.Keys, e.NewValues, e.OldValues 等。
    一小段例子代码:

        // 更新
        protected void grid1_RowUpdating(object sender, GridViewUpdateEventArgs e)
        {
            var row 
    = grid1.Rows[e.RowIndex];
            
    // 提取 Id 字段的值
            grid1.Columns[0].ExtractValuesFromCell(
                e.Keys,
                row.Cells[
    0as DataControlFieldCell,
                DataControlRowState.Edit,
                
    true /* include readonly */);

            
    // 提取 Name 字段的值
            grid1.Columns[1].ExtractValuesFromCell(
                e.NewValues,
                row.Cells[
    1as DataControlFieldCell,
                DataControlRowState.Edit,
                
    true /* include readonly */);

            var id 
    = int.Parse(e.Keys["id"].ToString());
            var name 
    = (string) e.NewValues["name"];

            
    // 执行相关的数据库更新操作
            
    // 
        }


    这样,在大多数场合我们可以尽可能多的使用 BoundField,并且也能正确读取到其编辑时的值,省下自定义 TemplateField 的一堆代码了。

  • 相关阅读:
    GAC的理解及其作用 [转]
    Binding Policy in .NET/ Assembly search order (Bin/GAC)
    Batch update
    Table-Valued Parameters in SQL Server 2008 (ADO.NET)
    EXT的bug 布局border 和 grid的cellediting
    ext 的controller中的refs的使用方法
    Ext 修改内容之后 不做任何动作 再次修改时的数据是原来第一次修改前的数据
    php 与mysql 数据库
    前端开发和后端开发
    http 你造吗?
  • 原文地址:https://www.cnblogs.com/ok519/p/1312413.html
Copyright © 2011-2022 走看看