GridView:两种数据绑定方法
 方法一:得到数据后,赋给DataSource属性,然后执行控件的DataBind()方法。

BLL.Article bll = new BLL.Article();
List<MODEL.Article> list = bll.GetArticle();
GridView1.DataSource = list;
GridView1.DataBind();

 方法二:使用数据源控件,赋给数据绑定控件的DataSourceId。
 DataSource属性和DataSourceId不能同时使用。如果先用数据源控件获得数据并绑定显示,在程序中又需要改用手动绑定的方法显示数据,要先给DataSourceId赋null。
 列设置中可选字段的用法:
 BoundField:显示要绑定的数据
 CheckBoxField:以CheckBox显示,一般与数据库中bit类型绑定
 HyperLinkField:以超链接形式显示,一般链接地址与绑定数据有关系
 ImageField:以图片形式显示,一般图片地址与绑定数据有关系
 ButtonField:以按钮形式显示
 CommandField:包含能够触发增删改事件的按钮,其实就是一个普通按钮,不同的是CommandName的设置。
 在GridView控件中,一个按钮的CommandName属性为edit,cancel,update,delete时,则会自动触发GridView的编辑,取消,更新,删除功能,须实现方法,然后重新绑定数据。Page_Loda事件中要进行IsPostBack判断。
 EditIndex 属性:指用户正在编辑的行,如果没有编辑任何行,设置为-1。AllowPaging属性:是否自动分页。AutoGenerateColumns属性:是否自动生成列。PageIndex属性:当前页。PageSize属性:页大小。Rows属性:所显示数据行的集合

protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            Bind();
        }
    }
    private void Bind()
    {
        BLL.Article bll = new BLL.Article();
        List<MODEL.Article> list = bll.GetArticle();
        GridView1.DataSource = list;
        GridView1.DataBind();
    }
    protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        if (e.CommandName == "a")
        {
            Response.Write("按钮1");
        }
        else if (e.CommandName == "b")
        {
            Response.Write("按钮2");
        }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        Bind();
    }
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -;
        Bind();
    }

 在GridView中获取用BoundFiled绑定的内容:GridView1.Rows[i].Cells[i].Text;处于编辑状态时获取用户输入的文本框中的值:(TextBox)GridView1.Rows[i].Cells[i].Controls[0].Text;如果用BoundFiled绑定的列被隐藏掉,那么隐藏的值无法获取到。用FindControl获取模版列中的值。

     //获取BoundFiled绑定字段的值
        Label2.Text = GridView1.Rows[].Cells[].Text;
        //获取编辑状态下字段的值
        CheckBox cb = (CheckBox)GridView1.Rows[].Cells[].Controls[];
        Label2.Text = cb.Checked.ToString();
        //获取模板项中的值
        Label2.Text = ((Label)GridView1.Rows[].Cells[].FindControl("Label1")).Text;
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        //获得修改后的值
        ].Controls[]).Text;
        ].Controls[]).Checked;
        //获得主键
        ].FindControl("Label1")).Text;
        //根据主键获得实体类模型
        MODEL.Article model = new BLL.Article().GetSingleArticle(Aid);
        model.Aisdel = IsDel;
        model.Atitle = Atitle;//修改属性
        )//如果编辑更新数据库成功
        {
            GridView1.EditIndex = -;//取消编辑状态
            Bind();//重新绑定数据
        }
    }
protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        ].FindControl("Label1")).Text;
        new BLL.Article().Del(Aid);
        Bind();
    }

.net之GridView、DataList、DetailsView(一)的更多相关文章

  1. gridview和detailsview的完美结合运用实现增删改

    原文发布时间为:2008-07-24 -- 来源于本人的百度文章 [由搬家工具导入] 1、因Gridview中没有增加记录,所以应利用datalistview或formview来弥补。 2、因为det ...

  2. .net之GridView、DataList、DetailsView(二)

    GridView自带分页功能,效率不高,适用于小数据量的显示. protected void GridView1_PageIndexChanging(object sender, GridViewPa ...

  3. 支持行单击、双击事件的GridView和DataList控件(译)

    支持行单击.双击事件的GridView和DataList控件(译)         让GridView 和 DataList 控件响应鼠标单击.双击事件.并且,使用 ClientScript.Regi ...

  4. Gridview、DataList、Repeater获取行索引号

    Gridview.DataList.Repeater如何获取行索引号?很多情况下都会用得到,下面贴出代码,注意行索引号是从0开始,不是从1开始,如果要从1开始,请在代码里面+1就行了. Gridvie ...

  5. ASP.NET--GridView配合DetailsView初使用

    1.GridView与DetailsView中的绑定模板不可以进行编辑的问题 方法:将要编辑的列转换为模板列---TemplateField <EditItemTemplate></ ...

  6. GridView控件

    GridView是ASP.NET 1.x的DataGrid控件的后继者.它提供了同样的基本功能集,同一时候添加�了大量扩展和改进.如前所述,DataGrid(ASP.NET 2.0仍然全然支持)是一个 ...

  7. Asp.net中GridView详解《转》

    ASP.NET服务器控件GridView 1         ASP.NET 服务器控件GridView使用 本教程不介绍服务器端控件的呈现,事件处理,状态等理论知识,只介绍服务器端控件的使用操作,如 ...

  8. asp.net中GridView传多个值到其它页面的方法

    网站开发中,在页面之间的跳转,经常会用到传值,其中可能会传递多个值. 一.CommadArgument传多个值到其他页面. 像Gridview dataList repeater等数据绑定控件中,可以 ...

  9. Repeater的分页

      Repeater控件是个好东西.轻量级.又好用.完全的自定义.但是,正是因为这些优点它没有自动分页的功能.这个需要研究一下.我看了一下起点等小说网站,那些什么推荐排名榜用Repeater控件那是很 ...

  10. ASP.NET 页生命周期

    ASP.NET 页运行时,此页将经历一个生命周期,在生命周期中将执行一系列处理步骤.这些步骤包括初始化.实例化控件.还原和维护状态.运行事件处理程序代码以及进行 呈现.了解页生命周期非常重要,因为这样 ...

随机推荐

  1. 中矿新生赛 H 璐神看岛屿【BFS/DFS求联通块/连通块区域在边界则此连通块无效】

    时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 32768K,其他语言65536K64bit IO Format: %lld 题目描述 璐神现在有张n*m大小的地图,地图上标明了陆地(用 ...

  2. HDU 5916: Harmonic Value Description

    题目描述 The harmonic value of the permutation $p_1,p_2,\cdots p_n$ is$$\sum_{i=1}^{n-1} gcd(p_i.p_{i+1} ...

  3. jquery 为表单动态添加元素

    $('<input />').attr('type','hidden')            .attr('name','type')            .attr('value', ...

  4. bzoj 5346: tree (其实是是某次雅礼集训的题)

    用prufer序列的公式直接dp,O(n^4)的算法简简单单就写出来了23333. 按理说 O(n^4)是需要优化成O(n^3)才能过的,然鹅我也不知道我怎么过了23333 (那就懒得优化了hhhhh ...

  5. Codeforces 908 D New Year and Arbitrary Arrangement

    Discription You are given three integers k, pa and pb. You will construct a sequence with the follow ...

  6. 1.14(java学习笔记)数组

    假如我们需要用到1000个相同类型的数据,肯定不可能创建1000个变量, 这样既不方便,也不直观,也不便于我们使用.这时就需要用到数组. 一.数组的声明与使用 public class Array { ...

  7. jsp笔记2(编译指令与动作指令)

    一.jsp的编译指令是通知jsp引擎的消息,不会生成输出. jsp的3个编译指令: page:针对当前页面的指令   include:包含另一个页面的指令   taglib:用于定义和访问自定义标签 ...

  8. 慎用SELECT INTO复制表

    原文:慎用SELECT INTO复制表 很多时候我们习惯于用SELECT INTO复制一个表或表结构,因为它方便,快捷,而且在某些情况下效率比INSERT INTO 效率要高一些.但是要注意: SEL ...

  9. delphi 浮点数float转换成十六进制字符串的方法(FloatToHex)

    重新书写了float型转为十六进制的delphi程序 Function FloatToHex(Value: single): string; var l, i: integer; HexText,te ...

  10. 纯CSS实现网站常用的五角星评分和分数展示交互效果

    最近做的一个项目涉及到评分和展示分数的模块,UI设计师也给了几个切好的图片,实现五角星评分方式很多,本质爱折腾的精神和对性能追求以及便于维护的考虑,搜集和尝试了很多方式,最终采用了纯css驱动的实现方 ...