http://www.cnblogs.com/shanymen/archive/2009/05/22/1486654.html

GridView控件是.net里的一个显示数据控件,该控件制作很人性化,基本上不用编写代码就可以完成数据绑定、分页、排序、编辑、删除、选定行等操作。

主要属性: 
Sort:根据指定的排序表达式和方向对 GridView 控件进行排序。

  • 编程的方法绑定数据,并实现分页

页面源代码中添加一个GridView控件(GridView1),并AllowPaging="True",设置PageIndexChanging事件。 
cs代码:

protected void bind() 
    { 
        //此处为GridView1绑定数据库 
        SqlConnection myConn = GetConnection(); 
        myConn.Open(); 
        string sqlStr = "select * from test"; 
        SqlDataAdapter myDa = new SqlDataAdapter(sqlStr, myConn); 
        DataSet myDs = new DataSet(); 
        myDa.Fill(myDs); 
        GridView1.DataSource = myDs; 
        GridView1.DataBind(); 
    } 
protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e) 
    { 
        GridView1.PageIndex = e.NewPageIndex; 
        this.bind(); 
    }
  • 编程方法实现排序

页面源代码中添加一个GridView控件(GridView1),并设置GridView1的Sorting事件。 
cs代码:

protected void Page_Load(object sender, EventArgs e) 
    { 
        if (!IsPostBack) 
        { 
            //设置信息字典,排序字段和排序方法 
            ViewState["SortOrder"] = "ID"; 
            ViewState["OrderDire"] = "ASC"; 
            this.bind(); 
        } 
    } 
public SqlConnection GetConnection() 
    { 
        //读取web.config中的连接字符串,创建SqlConnection连接 
        string myStr = ConfigurationManager.AppSettings["ConnectionString"].ToString(); 
        SqlConnection myConn = new SqlConnection(myStr); 
        return myConn; 
    } 
    protected void bind() 
    { 
        //此处为GridView1绑定数据库 
        SqlConnection myConn = GetConnection(); 
        myConn.Open(); 
        string sqlStr = "select * from test"; 
        SqlDataAdapter myDa = new SqlDataAdapter(sqlStr, myConn); 
        DataSet myDs = new DataSet(); 
        myDa.Fill(myDs);         //设置排序所用的字段和排序方法 
        string sort = (string)ViewState["SortOrder"] + " " + (string)ViewState["OrderDire"]; 
        GridView1.Sort = sort; 
        GridView1.DataSource = myDs; 
        GridView1.DataBind(); 
    } 
protected void GridView1_Sorting(object sender, GridViewSortEventArgs e) 
    {         //获取排序的字段 
        string sPage = e.SortExpression;         //如果目前排序方式与设置一致,则逆序 
        if (ViewState["SortOrder"].ToString() == sPage) 
        { 
            if (ViewState["OrderDire"].ToString() == "Desc") 
            { 
                ViewState["OrderDire"] = "ASC"; 
            } 
            else 
            { 
                ViewState["OrderDire"] = "Desc"; 
            } 
        } 
        else 
        { 
            ViewState["SortOrder"] = e.SortExpression; 
        } 
        this.bind(); 
    }
  • 选择GridView控件的行,在另一个GridView控件中显示相关数据

页面源代码中添加两个GridView控件(GridView1,GridView2),并设置GridView1的SelectedIndexChanging事件。GridView1已经绑定了一个数据表,当点击GridView1一行时,在GridView2中显示相关的另一张表中的数据。 
cs代码:

protected void GridView1_SelectedIndexChanging(object sender, GridViewSelectEventArgs e) 
    { 
        //提交编辑时,先取得要编辑行的主键值 
        int ID = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Value.ToString()); 
        string sqlStr = "delete from test where ID=" + ID; 
        SqlConnection con = new SqlConnection(); 
        //读取web.config中的连接字符串,创建SqlConnection连接 
        con.ConnectionString = ConfigurationManager.AppSettings["ConnectionString"].ToString(); 
        SqlDataAdapter myDa = new SqlDataAdapter(sqlStr, myConn); 
        DataSet myDs = new DataSet(); 
        myDa.Fill(myDs); 
        //将数据表绑定到GridView2 
        this.GridView2.DataSource = myDs; 
        GridView2.DataBind(); 
    }
  • 编程实现全选和全不选功能

页面源代码中添加两个GridView控件(GridView1),一个CheckBox控件(CheckBox1),设置CheckBox控件的AutoPostBack="True" ,为GridView1添加一个TemplateField列,并在编辑模版中为该列添加一个CheckBox 控件:<asp:TemplateField><ItemTemplate><asp:CheckBox ID="Check" runat="server" /></ItemTemplate></asp:TemplateField>。设置CheckBox的CheckedChanged事件。 
cs代码:

Code
  • 鼠标移动到任意行时,该行自动变成指定颜色,双击打开新页
    cs代码:
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        { 
            //鼠标移动到任意行时,该行自动变成指定颜色
            e.Row.Attributes.Add("onmouseover", "this.style.backgroundColor='#BEC9F6';this.style.color='buttontext';");
            e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor='';this.style.color='';");
            //双击打开新页
            e.Row.Attributes.Add("onclick", "window.open('FileInfo.aspx?id="+e.Row.Cells[0].Text+"')");
        }
    }

GRIDVIEW 控件的更多相关文章

  1. 扩展GridView控件——为内容项添加拖放及分组功能

    引言 相信大家对GridView都不陌生,是非常有用的控件,用于平铺有序的显示多个内容项.打开任何WinRT应用或者是微软合作商的网站,都会在APP中发现GridView的使用.“Tiles”提供了一 ...

  2. .Net语言 APP开发平台——Smobiler学习日志:用Gridview控件设计较复杂的表单

    最前面的话:Smobiler是一个在VS环境中使用.Net语言来开发APP的开发平台,也许比Xamarin更方便 一.目标样式 我们要实现上图中的效果,需要如下的操作: 1.从工具栏上的”Smobil ...

  3. GridView控件隐藏列

    GridView隐藏列visible="false" 后你就无法取得这列的值了 下面是迄今为止最简洁的解决方法了. protected void GVList_RowDataBou ...

  4. GridView控件中加自动排列序号

    GridView控件中加自动排列序号 为 Gridview 增加一个新的空白列,如下: <asp:BoundField  HeaderText="序号">    < ...

  5. asp.net GridView控件的列属性

    BoundField 默认的数据绑定类型,通常用于显示普通文本 CheckBoxField 显示布尔类型的数据.绑定数据为TRUE时,复选框数据绑定列为选中状态:绑定数据为FALSE时,则显示未选中状 ...

  6. ASP.NET中GridView控件删除数据的两种方法

      今天在用GridView控件时,发现了一个问题,就是使用GridView控件在删除数据时的问题.接下来我们通过模板列方式和CommandField方式删除某条数据讲解下两者之间的区别. 方式一:通 ...

  7. 027. asp.net中数据绑定控件之 GridView控件

    GridView控件支持下面的功能: 绑定至数据源控件, 如SqlDataSource 内置排序功能 内置更新和删除功能 内置分页功能 内置行选择功能 可以编程方式访问GridView对象模型以动态设 ...

  8. GridView控件 Reapter控件 DataList控件 的区别和用法

    ASP.NET三大控件: 1.GridView控件:表格视图控件,可以用来绑定结果集或者视图,用起来比较方便和灵活,三个控件中使用最多的控件 用法--- this.gridview1.DataSour ...

  9. GridView控件RowDataBound事件中获取列字段值的几种途径

    前台: <asp:TemplateField HeaderText="充值总额|账号余额"> <ItemTemplate> <asp:Label ID ...

随机推荐

  1. C#泛型类容器

    非泛型容器的缺点: (1) 性能问题. 在使用值类型时,必须将值类型装箱(Boxing)以便推送和存储,并且在将值类型从容器中取出时将其取消装箱(Unboxing).装箱和取消装箱都会根据值类型的权限 ...

  2. UWP/Win10新特性系列—UserConsentVerifier

    在UWP开发中,微软提供了新的用户许可验证方式-指纹(生物识别).Pin.密码验证.在爆料的新型Win10 Mobile移动设备中,会增加虹膜识别等先进的用户身份识别技术,微软现在统一了身份验证的AP ...

  3. activity 和 生命周期: 消息通信

    实际上关于activity大概流程已经了解了,在深入的话方向应该是ams的处理操作和界面创建和view绘制.这些话题之后再谈,activity是一个gui程序,其中离不开的就是消息通讯,也就是在消息循 ...

  4. ES6 - for...of

    for...of是一种用来遍历数据结构的方法,可遍历的对象包括:数组,对象,字符串,节点数组等 我们先来看一下现在存在的遍历方式: var arr=[1,2,3,4] (1)for循环 缺点:代码不够 ...

  5. excel导入导出

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using FS.Exten ...

  6. C++ Primer : 第十三章 : 拷贝控制之拷贝控制和资源管理

    定义行为像值的类 行为像值的类,例如标准库容器和std::string这样的类一样,类似这样的类我们可以简单的实现一个这样的类HasPtr. 在实现之前,我们需要: 定义一个拷贝构造函数,完成stri ...

  7. set的应用

    头文件 ;#include <set> 简单应用: begin()     返回set容器的第一个元素 end()   返回set容器的最后一个元素 clear()        删除se ...

  8. validate

    <?php $rules = [ "ip" => function ($var) {return ip2long($var);}, "email" ...

  9. maven项目修改java编译版本的方式

    背景 使用 maven 3.x 安装到本地后,创建的项目一般都是基于JDK1.5版本.而目前大多数的项目已经升级到1.6或以上,尤其是Servlet3.0 已经要求Java6或以上版本的环境,往往需要 ...

  10. SQL总结(一)基本查询

    SQL总结(一)基本查询 SQL查询的事情很简单,但是常常因为很简单的事情而出错.遇到一些比较复杂的查询我们更是忘记了SQL查询的基本语法. 本文希望通过简单的总结,把常用的查询方法予以总结,希望能够 ...