GridView72绝技

2024-03-13 15:08
文章标签 绝技 gridview72

本文主要是介绍GridView72绝技,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文来自:http://blog.csdn.net/21aspnet/archive/2007/03/25/1540301.aspx

快速预览:
GridView无代码分页排序
GridView选中,编辑,取消,删除
GridView正反双向排序
GridView和下拉菜单DropDownList结合
GridViewCheckBox结合
鼠标移到GridView某一行时改变该行的背景色方法一
鼠标移到GridView某一行时改变该行的背景色方法二
GridView实现删除时弹出确认对话框
GridView实现自动编号
GridView实现自定义时间货币等字符串格式
GridView实现用“...”代替超长字符串
GridView一般换行与强制换行
GridView显示隐藏某一列
GridView弹出新页面/弹出新窗口
GridView固定表头(不用javascript只用CSS2行代码,很好用)
GridView合并表头多重表头无错完美版(以合并33行举例)
GridView突出显示某一单元格(例如金额低于多少,分数不及格等)
GridView加入自动求和求平均值小计
GridView数据导入Excel/Excel数据读入GridView

1.GridView无代码分页排序

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv5.gif
1.AllowSorting
设为Trueaspx代码中是AllowSorting="True"
2.
默认110条,如果要修改每页条数,修改PageSize即可,在aspx代码中是PageSize="12"
3.
默认的是单向排序的,右击GridView弹出属性,选择AllowSortingTrue即可。

2.GridView选中,编辑,取消,删除:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv6.gif

后台代码:
你可以使用sqlhelper,本文没用。代码如下:
using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;

public partial class _Default : System.Web.UI.Page
{

//清清月儿http://blog.csdn.net/21aspnet 
    SqlConnection sqlcon;
    SqlCommand sqlcom;
    string strCon = "Data Source=(local);Database=
数据库名;Uid=帐号;Pwd=密码";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            bind();
        }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }

//删除
    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        string sqlstr = "delete from 
where id='" + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcon = new SqlConnection(strCon);
        sqlcom = new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        bind();
    }

//更新
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        string sqlstr = "update
set 字段1='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
字段2='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[2].Controls[0])).Text.ToString().Trim() + "',
字段3='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where id='"
            + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcom=new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        bind();
    }

//取消
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }

//绑定
    public void bind()
    {
        string sqlstr = "select * from
";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "id" };//
主键
        GridView1.DataBind();
        sqlcon.Close();
    }
}

前台主要代码:
                            ... ...
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="4"
                        ForeColor="#333333" GridLines="None" OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit">
                        <FooterStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />
                        <Columns>
                            <asp:BoundField DataField="
身份证号码" HeaderText="用户ID" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="用户姓名" />
                            <asp:BoundField DataField="
员工性别" HeaderText="性别" />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址" />
                            <asp:CommandField HeaderText="
选择" ShowSelectButton="True" />
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:CommandField HeaderText="
删除" ShowDeleteButton="True" />
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>


3.GridView正反双向排序:
效果图:点姓名各2次的排序,点其他也一样可以。
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv7.gif https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv8.gif
后台代码:
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;
using System.Data.SqlClient;
public partial class Default3 : System.Web.UI.Page
{

//清清月儿的博客http://blog.csdn.net/21aspnet 
    SqlConnection sqlcon;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            ViewState["SortOrder"] = "
身份证号码";
            ViewState["OrderDire"] = "ASC";
            bind();
        }
    }
    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"] = "Des";
        }c
        else
        {
            ViewState["SortOrder"] = e.SortExpression;
        }
        bind();
    }

    public void bind()
    {
       
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        DataView view = myds.Tables["
飞狐工作室"].DefaultView;
        string sort = (string)ViewState["SortOrder"] + " " + (string)ViewState["OrderDire"];
        view.Sort = sort;
        GridView1.DataSource = view;
        GridView1.DataBind();
        sqlcon.Close();
    }
}

前台主要代码:
<asp:GridView ID="GridView1" runat="server" AllowSorting="True" AutoGenerateColumns="False"
                        CellPadding="3" Font-Size="9pt" OnSorting="GridView1_Sorting" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px">
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                             <asp:BoundField DataField="
身份证号码" HeaderText="用户ID" SortExpression="身份证号码" />
                            <asp:BoundField DataField="
姓名" HeaderText="用户姓名" SortExpression="姓名"/>
                            <asp:BoundField DataField="
员工性别" HeaderText="性别" SortExpression="员工性别"/>
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址" SortExpression="家庭住址"/>
                               
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>

 

4.GridView和下拉菜单DropDownList结合:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv9.gif

后台代码:
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;
using System.Data.SqlClient;
public partial class Default4 : System.Web.UI.Page
{
    SqlConnection sqlcon;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        DropDownList ddl;
        if (!IsPostBack)
        {
            string sqlstr = "select top 5 * from
飞狐工作室";
            sqlcon = new SqlConnection(strCon);
            SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
            DataSet myds = new DataSet();
            sqlcon.Open();
            myda.Fill(myds, "
飞狐工作室");
            GridView1.DataSource = myds;
            GridView1.DataBind();
            for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
            {
                DataRowView mydrv = myds.Tables["
飞狐工作室"].DefaultView[i];
                if (Convert.ToString(mydrv["
员工性别"]).Trim() == "True")
                {
                    ddl = (DropDownList)GridView1.Rows[i].FindControl("DropDownList1");
                    ddl.SelectedIndex = 0;
                }
                if (Convert.ToString(mydrv["
员工性别"]).Trim() == "False")
                {
                    ddl = (DropDownList)GridView1.Rows[i].FindControl("DropDownList1");
                    ddl.SelectedIndex = 1;
                }
            }
            sqlcon.Close();
        }
    }
    public SqlDataReader ddlbind()
    {
        string sqlstr = "select distinct
员工性别 from 飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlCommand sqlcom = new SqlCommand(sqlstr, sqlcon);
        sqlcon.Open();
        return sqlcom.ExecuteReader();
    }

前台主要代码:
<asp:GridView ID="GridView1" runat="server" AllowSorting="True" AutoGenerateColumns="False"
                        CellPadding="3" Font-Size="9pt"  BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px">
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                             <asp:BoundField DataField="
身份证号码" HeaderText="用户ID" SortExpression="身份证号码" />
                            <asp:BoundField DataField="
姓名" HeaderText="用户姓名" SortExpression="姓名"/>
                            <asp:TemplateField HeaderText="
员工性别">
                                <ItemTemplate>
                                    <asp:DropDownList ID="DropDownList1" runat="server" DataSource='<%# ddlbind()%>' DataValueField="
员工性别" DataTextField="员工性别">
                                    </asp:DropDownList>
                                </ItemTemplate>
                            </asp:TemplateField>
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址" SortExpression="家庭住址"/>
                               
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>

5.GridViewCheckBox结合:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv10.gif

后台代码:

using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;

public partial class Default5 : System.Web.UI.Page
{
//
清清月儿http://blog.csdn.net/21aspnet
    SqlConnection sqlcon;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            bind();
        }
    }
    protected void CheckBox2_CheckedChanged(object sender, EventArgs e)
    {
        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
            if (CheckBox2.Checked == true)
            {
                cbox.Checked = true;
            }
            else
            {
                cbox.Checked = false;
            }
        }
    }
    protected void Button2_Click(object sender, EventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        SqlCommand sqlcom;
        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
            if (cbox.Checked == true)
            {

                string sqlstr = "delete from 飞狐工作室 where 身份证号码='" + GridView1.DataKeys[i].Value + "'";
                sqlcom = new SqlCommand(sqlstr, sqlcon);
                sqlcon.Open();
                sqlcom.ExecuteNonQuery();
                sqlcon.Close();
            }
        }
        bind();
    }
    protected void Button1_Click(object sender, EventArgs e)
    {
        CheckBox2.Checked = false;
        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
            cbox.Checked = false;
        }
    }
    public void bind()
    {
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "tb_Member");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        sqlcon.Close();
    }
}

前台主要代码:

<asp:GridView ID="GridView1" runat="server" AllowSorting="True" AutoGenerateColumns="False"
                        CellPadding="3" Font-Size="9pt"  BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px">
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                             <asp:TemplateField>
                                <ItemTemplate>
                                    <asp:CheckBox ID="CheckBox1" runat="server" />
                                </ItemTemplate>
                            </asp:TemplateField>
                             <asp:BoundField DataField="
身份证号码" HeaderText="用户ID" SortExpression="身份证号码" />
                            <asp:BoundField DataField="
姓名" HeaderText="用户姓名" SortExpression="姓名"/>
                           
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址" SortExpression="家庭住址"/>
                               
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>
                     <asp:CheckBox ID="CheckBox2" runat="server" AutoPostBack="True" Font-Size="9pt" OnCheckedChanged="CheckBox2_CheckedChanged"
                        Text="
全选" />
                    <asp:Button ID="Button1" runat="server" Font-Size="9pt" Text="
取消" OnClick="Button1_Click" />
                    <asp:Button ID="Button2" runat="server" Font-Size="9pt" Text="
删除" OnClick="Button2_Click" />

6.鼠标移到GridView某一行时改变该行的背景色方法一:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv12.gif
做法:
双击GridViewOnRowDataBound事件;
在后台的GridView1_RowDataBound()方法添加代码,最后代码如下所示:
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        int i;
        //
执行循环,保证每条数据都可以更新
        for (i = 0; i < GridView1.Rows.Count; i++)
        {
            //
首先判断是否是数据行
            if (e.Row.RowType == DataControlRowType.DataRow)
            {
                //
当鼠标停留时更改背景色
                e.Row.Attributes.Add("onmouseover", "c=this.style.backgroundColor;this.style.backgroundColor='#00A9FF'");
                //
当鼠标移开时还原背景色
                e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor=c");
            }
        }

    }

前台代码:
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>
实现鼠标划过改变GridView的行背景色 清清月儿http://blog.csdn.net/21aspnet </title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="
身份证号码"
            DataSourceID="SqlDataSource1" AllowSorting="True" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" CellPadding="3" Font-Size="12px" OnRowDataBound="GridView1_RowDataBound">
            <Columns>
                <asp:BoundField DataField="
身份证号码" HeaderText="身份证号码" ReadOnly="True" SortExpression="身份证号码" />
                <asp:BoundField DataField="
姓名" HeaderText="姓名" SortExpression="姓名" />
                <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址" SortExpression="家庭住址" />
                <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" SortExpression="邮政编码" />
            </Columns>
            <FooterStyle BackColor="White" ForeColor="#000066" />
            <RowStyle ForeColor="#000066" />
            <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
            <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
            <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
        </asp:GridView>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:
北风贸易ConnectionString1 %>"
            SelectCommand="SELECT top 5 [
身份证号码], [姓名], [员工性别], [家庭住址], [邮政编码] FROM [飞狐工作室]" DataSourceMode="DataReader"></asp:SqlDataSource>
   
    </div>
    </form>
</body>
</html>

7.鼠标移到GridView某一行时改变该行的背景色方法二:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv13.gif

做法:和上面的一样就是代码不同
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        //int i;
       
执行循环,保证每条数据都可以更新
        //for (i = 0; i < GridView1.Rows.Count; i++)
        //{
        //    //
首先判断是否是数据行
        //    if (e.Row.RowType == DataControlRowType.DataRow)
        //    {
        //        //
当鼠标停留时更改背景色
        //        e.Row.Attributes.Add("onmouseover", "c=this.style.backgroundColor;this.style.backgroundColor='#00A9FF'");
        //        //
当鼠标移开时还原背景色
        //        e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor=c");
        //    }
        //}
        //
如果是绑定数据行
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            //
鼠标经过时,行背景色变
            e.Row.Attributes.Add("onmouseover", "this.style.backgroundColor='#E6F5FA'");
            //
鼠标移出时,行背景色变
            e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor='#FFFFFF'");
        }

    }

8.GridView实现删除时弹出确认对话框:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv14.gif

实现方法:
双击GridViewOnRowDataBound事件;
在后台的GridView1_RowDataBound()方法添加代码,最后代码如下所示:

    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        //
如果是绑定数据行
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
             if (e.Row.RowState == DataControlRowState.Normal || e.Row.RowState == DataControlRowState.Alternate)
            {
                ((LinkButton)e.Row.Cells[6].Controls[0]).Attributes.Add("onclick", "javascript:return confirm('
你确认要删除:/"" + e.Row.Cells[1].Text + "/"?')");
            }
        }

    }

9.GridView实现自动编号:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv15.gif

实现方法:
双击GridViewOnRowDataBound事件;
在后台的GridView1_RowDataBound()方法添加代码,最后代码如下所示:
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        //
如果是绑定数据行 //清清月儿http://blog.csdn.net/21aspnet 
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
           
鼠标经过时,行背景色变
            //e.Row.Attributes.Add("onmouseover", "this.style.backgroundColor='#E6F5FA'");
           
鼠标移出时,行背景色变
            //e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor='#FFFFFF'");

            当有编辑列时,避免出错,要加的RowState判断
            //if (e.Row.RowState == DataControlRowState.Normal || e.Row.RowState == DataControlRowState.Alternate)
            //{
            //    ((LinkButton)e.Row.Cells[6].Controls[0]).Attributes.Add("onclick", "javascript:return confirm('
你确认要删除:/"" + e.Row.Cells[1].Text + "/"?')");
            //}

        }
        if (e.Row.RowIndex != -1)
        {
            int id = e.Row.RowIndex + 1;
            e.Row.Cells[0].Text = id.ToString();
        }

    }

 

注意这时最好把前台的第一列的表头该为编号,因为以前的第一列被吃掉了。
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="3" OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px" OnRowDataBound="GridView1_RowDataBound">
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="用户姓名" />
                            <asp:BoundField DataField="
员工性别" HeaderText="性别" />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址" />
                            <asp:CommandField HeaderText="
选择" ShowSelectButton="True" />
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:CommandField HeaderText="
删除" ShowDeleteButton="True" />
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>

10.GridView实现自定义时间货币等字符串格式:

效果图:
1-未格式化前
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv16.gif
2-格式化后
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv17.gif
解决方法:
asp.net 2.0中,如果要在绑定列中显示比如日期格式等,如果用下面的方法是显示不了的

<asp :BoundField DataField="CreationDate"
DataFormatString="{0:M-dd-yyyy}"
HeaderText="CreationDate" />

主要是由于htmlencode属性默认设置为true,已防止XSS攻击,安全起见而用的,所以,可以有以下两种方法解决

1

<asp :GridView ID="GridView1" runat="server">
<columns>
<asp :BoundField DataField="CreationDate"
DataFormatString="{0:M-dd-yyyy}"
HtmlEncode="false"
HeaderText="CreationDate" />
</columns>
</asp>

htmlencode设置为false即可

另外的解决方法为,使用模版列

<asp :GridView ID="GridView3" runat="server" >
<columns>
<asp :TemplateField HeaderText="CreationDate" >
<edititemtemplate>
<asp :Label ID="Label1" runat="server"
Text='<%# Eval("CreationDate", "{0:M-dd-yyyy}") %>'>
</asp>
</edititemtemplate>
<itemtemplate>
<asp :Label ID="Label1" runat="server"
Text=’<%# Bind("CreationDate", "{0:M-dd-yyyy}") %>'>
</asp>
</itemtemplate>
</asp>
</columns>
</asp>

前台代码:
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="身份证号码"
            DataSourceID="SqlDataSource1" AllowSorting="True" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" CellPadding="3" Font-Size="12px" OnRowDataBound="GridView1_RowDataBound">
            <Columns>
                <asp:BoundField DataField="
身份证号码" HeaderText="身份证号码" ReadOnly="True" SortExpression="身份证号码" />
                <asp:BoundField DataField="
姓名" HeaderText="姓名" SortExpression="姓名" />
                <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" SortExpression="邮政编码" />
                <asp:BoundField DataField="
出生日期" HeaderText="出生日期" SortExpression="出生日期" />
                <asp:BoundField DataField="
起薪" HeaderText="起薪" SortExpression="起薪" />
            </Columns>
            <FooterStyle BackColor="White" ForeColor="#000066" />
            <RowStyle ForeColor="#000066" />
            <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
            <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
            <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
        </asp:GridView>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:
北风贸易ConnectionString1 %>"
            SelectCommand="SELECT top 5 [
出生日期], [起薪], [身份证号码], [姓名], [家庭住址], [邮政编码] FROM [飞狐工作室]" DataSourceMode="DataReader"></asp:SqlDataSource>

附录-常用格式化公式:
{0:C}  货币;
{0:D4}
0填充的4个字符宽的字段中显示整数;
{0:000.0}
四舍五入小数点保留第几位有效数字;
{0:N2}
小数点保留2位有效数字;{0:N2}%   小数点保留2位有效数字加百分号;
{0:D}
长日期;{0:d}短日期;{0:yy-MM-dd}   例如07-3-25;;{0:yyyy-MM-dd}  例如2007-3-25

 11.GridView实现用“...”代替超长字符串:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv18.gif
解决方法:数据绑定后过滤每一行即可
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            DataRowView mydrv;
            string gIntro;
            if (GridView1.PageIndex == 0)
            {
                mydrv = myds.Tables["
飞狐工作室"].DefaultView[i];//表名
                gIntro = Convert.ToString(mydrv["
家庭住址"]);//所要处理的字段
                GridView1.Rows[i].Cells[3].Text = SubStr(gIntro, 2);
            }
            else
            {
                mydrv = myds.Tables["
飞狐工作室"].DefaultView[i + (5 * GridView1.PageIndex)];
                gIntro = Convert.ToString(mydrv["
家庭住址"]);
                GridView1.Rows[i].Cells[3].Text = SubStr(gIntro, 2);
            }
        } 

调用的方法:

    public string SubStr(string sString, int nLeng)
    {
        if (sString.Length <= nLeng)
        {
            return sString;
        }
        string sNewStr = sString.Substring(0, nLeng);
        sNewStr = sNewStr + "...";
        return sNewStr;
    }

后台全部代码:
using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;

public partial class _Default : System.Web.UI.Page
{
    SqlConnection sqlcon;
    SqlCommand sqlcom;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            ViewState["SortOrder"] = "
身份证号码";
            ViewState["OrderDire"] = "ASC";
            bind();
        }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }
    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        string sqlstr = "delete from
飞狐工作室 where 身份证号码='" + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcon = new SqlConnection(strCon);
        sqlcom = new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        bind();
    }
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        string sqlstr = "update
飞狐工作室 set 姓名='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
家庭住址='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where
身份证号码='"
            + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcom=new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        bind();
    }
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }
    public void bind()
    {
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            DataRowView mydrv;
            string gIntro;
            if (GridView1.PageIndex == 0)
            {
                mydrv = myds.Tables["
飞狐工作室"].DefaultView[i];
                gIntro = Convert.ToString(mydrv["
家庭住址"]);
                GridView1.Rows[i].Cells[3].Text = SubStr(gIntro, 2);
            }
            else
            {
                mydrv = myds.Tables["
飞狐工作室"].DefaultView[i + (5 * GridView1.PageIndex)];
                gIntro = Convert.ToString(mydrv["
家庭住址"]);
                GridView1.Rows[i].Cells[3].Text = SubStr(gIntro, 2);
            }
        }
       
        sqlcon.Close();
    }
    public string SubStr(string sString, int nLeng)
    {
        if (sString.Length <= nLeng)
        {
            return sString;
        }
        string sNewStr = sString.Substring(0, nLeng);
        sNewStr = sNewStr + "...";
        return sNewStr;
    }
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        //
如果是绑定数据行 
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
           
鼠标经过时,行背景色变
            //e.Row.Attributes.Add("onmouseover", "this.style.backgroundColor='#E6F5FA'");
           
鼠标移出时,行背景色变
            //e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor='#FFFFFF'");

            当有编辑列时,避免出错,要加的RowState判断
            //if (e.Row.RowState == DataControlRowState.Normal || e.Row.RowState == DataControlRowState.Alternate)
            //{
            //    ((LinkButton)e.Row.Cells[6].Controls[0]).Attributes.Add("onclick", "javascript:return confirm('
你确认要删除:/"" + e.Row.Cells[1].Text + "/"?')");
            //}

        }
        if (e.Row.RowIndex != -1)
        {
            int id = e.Row.RowIndex + 1;
            e.Row.Cells[0].Text = id.ToString();
        }

    }
}

 11.GridView一般换行与强制换行:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv19.gif
首先设置<asp:BoundField DataField="家庭住址" HeaderText="家庭住址"  ItemStyle-Width="100" />
gridview
里有一列绑定的数据很长,显示的时候在一行里面显示,页面拉得很宽。
原因是连续英文段为一个整体导致的,在RowDataBound中添加上了一句e.Row.Cells[2].Style.Add("word-break", "break-all")就可以。

如果要给所有的列增加此属性:
 protected void Page_Load(object sender, EventArgs e)
    {
        //
正常换行
        GridView1.Attributes.Add("style", "word-break:keep-all;word-wrap:normal");
        //
下面这行是自动换行
        GridView1.Attributes.Add("style", "word-break:break-all;word-wrap:break-word");
        if (!IsPostBack)
        {
             bind();//
调用数据绑定即可
        }
    }
总之:善用CSSword-break:break-all;word-wrap:break-word属性即可,这个属性是通用的对于顽固的南换行问题都可以解决,不局限于GridView

 12.GridView显示隐藏某一列:
本方案为月儿独创,不同于网上其他方式,我觉得用一个CheckBox更人性化,这样可以隐藏不必要的列,让用户自己选择需要出现的列,在处理多列时这是一个很好的解决方案!

效果图:
1-开始
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv22.gif
2-点击显示的CheckBox
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv21.gif

解决方案:
public void bind()
    {
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        sqlcon.Close();
        GridView1.Columns[3].Visible = false;//一开始隐藏
        CheckBox1.Checked = false;//如果不这样后面的代码会把他True
    }

双击CheckBox1,在CheckedChanged方法里写上代码,最后代码如下:
protected void CheckBox1_CheckedChanged(object sender, EventArgs e)
    {
         GridView1.Columns[3].Visible=! GridView1.Columns[3].Visible;
         Response.Write("GridView1
的第4列现在的显示隐藏状态是:"+GridView1.Columns[3].Visible.ToString());
    }

注意:CheckBox1AutoPostBackTrue

后台全部代码如下:

using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;

public partial class _Default : System.Web.UI.Page
{
    SqlConnection sqlcon;
    SqlCommand sqlcom; 
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            ViewState["SortOrder"] = "
身份证号码";
            ViewState["OrderDire"] = "ASC";
            bind();
                   }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }
    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        string sqlstr = "delete from
飞狐工作室 where 身份证号码='" + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcon = new SqlConnection(strCon);
        sqlcom = new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        bind();
    }
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        string sqlstr = "update
飞狐工作室 set 姓名='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
家庭住址='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where
身份证号码='"
            + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcom=new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        bind();
    }
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }
    public void bind()
    {
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        sqlcon.Close();
        GridView1.Columns[3].Visible = false;
        CheckBox1.Checked = false;
    }
    protected void CheckBox1_CheckedChanged(object sender, EventArgs e)
    {
         GridView1.Columns[3].Visible=! GridView1.Columns[3].Visible;
         Response.Write("GridView1
的第4列现在的显示隐藏状态是:"+GridView1.Columns[3].Visible.ToString());
    }
}

前台代码:
<!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>GridView
显示隐藏列 清清月儿http://blog.csdn.net/21aspnet </title>
</head>
<body style="font-size=12px">
    <form id="form1" runat="server">
    <div>
                   <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="3" OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px"  >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="用户姓名" />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" SortExpression="邮政编码" />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                            <asp:CommandField HeaderText="
选择" ShowSelectButton="True" />
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:CommandField HeaderText="
删除" ShowDeleteButton="True" />
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>
        <asp:CheckBox ID="CheckBox1" runat="server" AutoPostBack="True" Font-Size="12px"
            OnCheckedChanged="CheckBox1_CheckedChanged" Text="
显示隐藏家庭住址" /></div>
    </form>
</body>
</html>

 13.GridView弹出新页面/弹出制定大小位置新窗口:

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv23.gif

方案一:简单的方法,新窗口不固定大小
 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="3" OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px"  >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" SortExpression="邮政编码" />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                           
<asp:HyperLinkField HeaderText="姓名" Text="姓名" DataNavigateUrlFields="姓名" DataNavigateUrlFormatString="Default6.aspx?GoodsID={0}" Target="mainframe" NavigateUrl="~/Default6.aspx" DataTextField="姓名" >
                    </asp:HyperLinkField>
                            <asp:CommandField HeaderText="选择" ShowSelectButton="True" />
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:CommandField HeaderText="
删除" ShowDeleteButton="True" />
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>
DataNavigateUrlFields
是链接的字段名,DataNavigateUrlFormatString是路径。

方案二:精确控制弹出窗口大小位置
<asp:HyperLinkColumn DataNavigateUrlField="EmployeeID" DataNavigateUrlFormatString="javascript:varwin=window.open('detail.aspx?ID={0}',null,'width=300,height=200');window.Close();"
       DataTextField="LastName" HeaderText="LastName"></asp:HyperLinkColumn>

使用的是结合javascriptwindow.open方法,关于window.open的参数网上有很多帖子,本站也有许多参考
弹出窗口大全 http://blog.csdn.net/21aspnet/archive/2004/10/25/150231.aspx   即可!

  14.GridView固定表头(不用javascript只用CSS!,很好用)

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv24.gif

代码:
<!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>GridView
固定表头 清清月儿http://blog.csdn.net/21aspnet </title>
        <style>
.Freezing
   {
   
   position:relative ;
   table-layout:fixed;
   top:expression(this.offsetParent.scrollTop);  
   z-index: 10;
   }

.Freezing th{text-overflow:ellipsis;overflow:hidden;white-space: nowrap;padding:2px;}
</style>
</head>
<body style="font-size=12px">
    <form id="form1" runat="server">
    <div style="overflow-y: scroll; height: 200px;width:300px" id="dvBody">
                   <asp:GridView ID="GridView1" runat="server"    AutoGenerateColumns="False" CellPadding="3" OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px" OnRowCreated="GridView1_RowCreated"  >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" SortExpression="邮政编码" />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                            <asp:BoundField DataField="
姓名" HeaderText="姓名"  />
                           
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left"  CssClass="ms-formlabel DataGridFixedHeader"/>
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" CssClass="Freezing"
/>
                    </asp:GridView>
        </div>

    </form>
</body>
</html>

用法:CSS设如上的样式,HeaderStyleCssClass="Freezing,套住GridViewDiv设置高度宽度 <div style="overflow-y: scroll; height: 200px;width:200px" >

15.GridView合并表头多重表头无错完美版(以合并33行举例)

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv25.gif


后台代码:
using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;
using System.Drawing;
public partial class _Default : System.Web.UI.Page
{
    SqlConnection sqlcon;
    SqlCommand sqlcom;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            bind();
           
        }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        string sqlstr = "update
飞狐工作室 set 姓名='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
家庭住址='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where
身份证号码='"
            + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcom=new SqlCommand(sqlstr,sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        bind();
    }
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }
    public void bind()
    {
        string sqlstr = "select top 10 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        sqlcon.Close();
    }

//这里就是解决方案
    protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e)
    {
        switch (e.Row.RowType)
        {
            case DataControlRowType.Header:
                //
第一行表头
                TableCellCollection tcHeader = e.Row.Cells;
                tcHeader.Clear();
                tcHeader.Add(new TableHeaderCell());
                tcHeader[0].Attributes.Add("rowspan", "3"); //
Row
                tcHeader[0].Attributes.Add("bgcolor", "white");
                tcHeader[0].Text = "";
                tcHeader.Add(new TableHeaderCell());
                //tcHeader[1].Attributes.Add("bgcolor", "Red");
                tcHeader[1].Attributes.Add("colspan", "6"); //
Column
                tcHeader[1].Text = "
全部信息</th></tr><tr>";

                //第二行表头
                tcHeader.Add(new TableHeaderCell());
                tcHeader[2].Attributes.Add("bgcolor", "DarkSeaGreen");
                tcHeader[2].Text = "
身份证号码";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[3].Attributes.Add("bgcolor", "LightSteelBlue");
                tcHeader[3].Attributes.Add("colspan", "2");
                tcHeader[3].Text = "
基本信息";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[4].Attributes.Add("bgcolor", "DarkSeaGreen");
                tcHeader[4].Text = "
福利";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[5].Attributes.Add("bgcolor", "LightSteelBlue");
                tcHeader[5].Attributes.Add("colspan", "2");
                tcHeader[5].Text = "
联系方式</th></tr><tr>";

                //第三行表头
                tcHeader.Add(new TableHeaderCell());
                tcHeader[6].Attributes.Add("bgcolor", "Khaki");
                tcHeader[6].Text = "
身份证号码";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[7].Attributes.Add("bgcolor", "Khaki");
                tcHeader[7].Text = "
姓名";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[8].Attributes.Add("bgcolor", "Khaki");
                tcHeader[8].Text = "
出生日期";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[9].Attributes.Add("bgcolor", "Khaki");
                tcHeader[9].Text = "
薪水";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[10].Attributes.Add("bgcolor", "Khaki");
                tcHeader[10].Text = "
家庭住址";
                tcHeader.Add(new TableHeaderCell());
                tcHeader[11].Attributes.Add("bgcolor", "Khaki");
                tcHeader[11].Text = "
邮政编码";
                break;
        }
    }
}

前台:
<!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>GridView
合并多重表头表头 清清月儿http://blog.csdn.net/21aspnet </title>
</head>
<body >
    <form id="form1" runat="server">
    <div  >
                   <asp:GridView ID="GridView1" runat="server"    AutoGenerateColumns="False" CellPadding="3"  OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px" OnRowCreated="GridView1_RowCreated"  >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="姓名"  />
                            <asp:BoundField DataField="
出生日期" HeaderText="邮政编码"  />
                             <asp:BoundField DataField="
起薪" HeaderText="起薪"  />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" />
                          
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left"  CssClass="ms-formlabel DataGridFixedHeader"/>
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>
        </div>

    </form>
</body>
</html>

16.GridView突出显示某一单元格(例如金额低于多少,分数不及格等)

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv28.gif

解决方案:主要是绑定后过滤
 GridView1.DataBind();
        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            DataRowView mydrv = myds.Tables["
飞狐工作室"].DefaultView[i];
            string score = Convert.ToString(mydrv["
起薪"]);
            if (Convert.ToDouble(score) < 34297.00)//
大家这里根据具体情况设置可能ToInt32等等
            {
                GridView1.Rows[i].Cells[4].BackColor = System.Drawing.Color.Red;
            }
        }
        sqlcon.Close();

全部后台代码:

using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;
using System.Drawing;

public partial class Default7 : System.Web.UI.Page
{
    SqlConnection sqlcon;
    SqlCommand sqlcom;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            bind();

        }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        string sqlstr = "update
飞狐工作室 set 姓名='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
家庭住址='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where
身份证号码='"
            + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcom = new SqlCommand(sqlstr, sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        bind();
    }
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }
    public void bind()
    {
        string sqlstr = "select top 10 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
        {
            DataRowView mydrv = myds.Tables["
飞狐工作室"].DefaultView[i];
            string score = Convert.ToString(mydrv["
起薪"]);
            if (Convert.ToDouble(score) < 34297.00)
//大家这里根据具体情况设置可能ToInt32等等

            {
                GridView1.Rows[i].Cells[4].BackColor = System.Drawing.Color.Red;
            }
        }
        sqlcon.Close();
    }
}

前台代码:

<!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 id="Head1" runat="server">
    <title>GridView
突出显示某一单元格 清清月儿http://blog.csdn.net/21aspnet </title>
</head>
<body >
    <form id="form1" runat="server">
    <div  >
                   <asp:GridView ID="GridView1" runat="server"    AutoGenerateColumns="False" CellPadding="3"  OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px"  >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="姓名"  />
                            <asp:BoundField DataField="
出生日期" HeaderText="邮政编码"  />
                             <asp:BoundField DataField="
起薪" HeaderText="起薪"  DataFormatString="{0:C}" HtmlEncode="false"/>
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" />
                          
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left"  CssClass="ms-formlabel DataGridFixedHeader"/>
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>
        </div>

    </form>
</body>
</html>

 17.GridView加入自动求和求平均值小计

效果图: https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv30.gif
解决方案:    
private double sum = 0;//
取指定列的数据和,你要根据具体情况对待可能你要处理的是int
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
       
        if (e.Row.RowIndex >= 0)
        {
            sum += Convert.ToDouble(e.Row.Cells[6].Text);
        }
        else if (e.Row.RowType == DataControlRowType.Footer)
        {
            e.Row.Cells[5].Text = "
总薪水为:";
            e.Row.Cells[6].Text = sum.ToString();
            e.Row.Cells[3].Text = "
平均薪水为:";
            e.Row.Cells[4].Text = ((int)(sum / GridView1.Rows.Count)).ToString();
           
        }
    }

后台全部代码:
using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;
using System.Drawing;

public partial class Default7 : System.Web.UI.Page
{
    SqlConnection sqlcon;
    SqlCommand sqlcom;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            bind();

        }
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        sqlcon = new SqlConnection(strCon);
        string sqlstr = "update
飞狐工作室 set 姓名='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
家庭住址='"
            + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where
身份证号码='"
            + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
        sqlcom = new SqlCommand(sqlstr, sqlcon);
        sqlcon.Open();
        sqlcom.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        bind();
    }
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }
    public void bind()
    {
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        sqlcon.Close();
    }
    private double sum = 0;//
取指定列的数据和
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
       
        if (e.Row.RowIndex >= 0)
        {
            sum += Convert.ToDouble(e.Row.Cells[6].Text);
        }
        else if (e.Row.RowType == DataControlRowType.Footer)
        {
            e.Row.Cells[5].Text = "
总薪水为:";
            e.Row.Cells[6].Text = sum.ToString();
            e.Row.Cells[3].Text = "
平均薪水为:";
            e.Row.Cells[4].Text = ((int)(sum / GridView1.Rows.Count)).ToString();
           
        }
    }
}
前台:唯一的花头就是设置ShowFooter="True" ,否则默认表头为隐藏的!
<asp:GridView ID="GridView1" runat="server"    AutoGenerateColumns="False" CellPadding="3"  OnRowEditing="GridView1_RowEditing"
                        OnRowUpdating="GridView1_RowUpdating" OnRowCancelingEdit="GridView1_RowCancelingEdit" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px" OnRowDataBound="GridView1_RowDataBound" ShowFooter="True"  >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:CommandField HeaderText="
编辑" ShowEditButton="True" />
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="姓名"  />
                            <asp:BoundField DataField="
出生日期" HeaderText="邮政编码"  />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" />
                            <asp:BoundField DataField="
起薪" HeaderText="起薪"  />
                          
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left"  CssClass="ms-formlabel DataGridFixedHeader"/>
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>

 

 18.GridView数据导入Excel/Excel数据读入GridView

效果图:
https://p-blog.csdn.net/images/p_blog_csdn_net/21aspnet/286353/o_gv31.gif

解决方案:
页面增加一个按钮,单击事件添加如下方法:
protected void Button1_Click(object sender, EventArgs e)
    {
        Export("application/ms-excel", "
学生成绩报表.xls");
    }

    private void Export(string FileType, string FileName)
    {
        Response.Charset = "GB2312";
        Response.ContentEncoding = System.Text.Encoding.UTF7;
        Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString());
        Response.ContentType = FileType;
        this.EnableViewState = false;
        StringWriter tw = new StringWriter();
        HtmlTextWriter hw = new HtmlTextWriter(tw);
        GridView1.RenderControl(hw);
        Response.Write(tw.ToString());
        Response.End();
    }
//
如果没有下面方法会报错类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内
    public override void VerifyRenderingInServerForm(Control control)
    {
    }
还有由于是文件操作所以要引入名称空间IOText

后台代码:
using System;
using System.Data;
using System.Configuration;
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;
using System.Data.SqlClient;
using System.Drawing;
using System.IO;
using System.Text;
public partial class Default7 : System.Web.UI.Page
{
    SqlConnection sqlcon;
    SqlCommand sqlcom;
    string strCon = "Data Source=(local);Database=
北风贸易;Uid=sa;Pwd=sa";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            bind();

        }
    }
   
    public void bind()
    {
        string sqlstr = "select top 5 * from
飞狐工作室";
        sqlcon = new SqlConnection(strCon);
        SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
        DataSet myds = new DataSet();
        sqlcon.Open();
        myda.Fill(myds, "
飞狐工作室");
        GridView1.DataSource = myds;
        GridView1.DataKeyNames = new string[] { "
身份证号码" };
        GridView1.DataBind();
        sqlcon.Close();
    }

    protected void Button1_Click(object sender, EventArgs e)
    {
        Export("application/ms-excel", "
学生成绩报表.xls");
    }

    private void Export(string FileType, string FileName)
    {
        Response.Charset = "GB2312";
        Response.ContentEncoding = System.Text.Encoding.UTF7;
        Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString());
        Response.ContentType = FileType;
        this.EnableViewState = false;
        StringWriter tw = new StringWriter();
        HtmlTextWriter hw = new HtmlTextWriter(tw);
        GridView1.RenderControl(hw);
        Response.Write(tw.ToString());
        Response.End();
    }
    public override void VerifyRenderingInServerForm(Control control)
    {
    }
   
}

前台
<asp:GridView ID="GridView1" runat="server"    AutoGenerateColumns="False" CellPadding="3" 
                         BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" Font-Size="12px"   >
                        <FooterStyle BackColor="White" ForeColor="#000066" />
                        <Columns>
                            <asp:BoundField DataField="
身份证号码" HeaderText="编号" ReadOnly="True" />
                            <asp:BoundField DataField="
姓名" HeaderText="姓名"  />
                            <asp:BoundField DataField="
出生日期" HeaderText="邮政编码"  />
                            <asp:BoundField DataField="
家庭住址" HeaderText="家庭住址"  />
                            <asp:BoundField DataField="
邮政编码" HeaderText="邮政编码" />
                            <asp:BoundField DataField="
起薪" HeaderText="起薪"  />
                          
                        </Columns>
                        <RowStyle ForeColor="#000066" />
                        <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left"  CssClass="ms-formlabel DataGridFixedHeader"/>
                        <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
                    </asp:GridView>
        <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="
导出" />

读取Excel数据的代码:这个很简单的
private DataSet CreateDataSource()
    {
        string strCon;
        strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Server.MapPath("excel.xls") + "; Extended Properties=Excel 8.0;";
        OleDbConnection olecon = new OleDbConnection(strCon);
        OleDbDataAdapter myda = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", strCon);
        DataSet myds = new DataSet();
        myda.Fill(myds);
        return myds;
    }
    protected void Button1_Click(object sender, EventArgs e)
    {
        GridView1.DataSource = CreateDataSource();
        GridView1.DataBind();
    }

由于时间关系,这个文章先到此。有时间再写,其实还有很多技巧,不过我觉得如果能融汇贯通应该可以举一反三

 




Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1540301

 

上一篇: ASP.NET2.0轻松搞定统计图表【月儿原创】  | 下一篇: C#精髓【月儿原创】第三讲 C#泛型有什么好处

 

评论

#   http://www.csdn.net/ui/images/blank.gif  Zeilg1981 发表于2007-03-26 09:24:12  IP: 61.170.206.*

辛苦了~收藏

 

#   http://www.csdn.net/ui/images/blank.gif  wenwenti2 发表于2007-03-26 09:53:52  IP: 222.212.103.*

高手啊.~~~~~~~~~~

 

#   http://www.csdn.net/ui/images/blank.gif  iloveaspx 发表于2007-03-26 10:06:11  IP: 221.192.177.*

厉害的不得了,珍藏一下哦

 

#   http://www.csdn.net/ui/images/blank.gif  QQ272821361 发表于2007-03-26 10:16:47  IP: 60.173.224.*

今天幸运了,碰到了个高手了,以后要多多指教啊!!

 

#   http://www.csdn.net/ui/images/blank.gif  QQ272821361 发表于2007-03-26 11:04:37  IP: 60.173.224.*

再顶下!!!

收获不小...

 

#   http://www.csdn.net/ui/images/blank.gif  wt_3333 发表于2007-03-26 12:34:21  IP: 222.38.97.*

向高手致敬

 

#   http://www.csdn.net/ui/images/blank.gif  强子 发表于2007-03-26 12:53:22  IP: 218.104.39.*

谢谢了!

 

#   http://www.csdn.net/ui/images/blank.gif  delphigbg 发表于2007-03-26 12:56:02  IP: 218.247.53.*

发现宝藏了.

 

#   http://www.csdn.net/ui/images/blank.gif  guomaomao1981 发表于2007-03-26 13:04:54  IP: 218.12.56.*

收藏,lz辛苦了。

 

#   http://www.csdn.net/ui/images/blank.gif  sdtsfhh 发表于2007-03-26 13:31:11  IP: 221.8.56.*

编码狂人

 

#   http://www.csdn.net/ui/images/blank.gif  showrock 发表于2007-03-26 14:07:53  IP: 59.108.6.*

真系太厉害啦,收藏

 

#   http://www.csdn.net/ui/images/blank.gif  chieftech 发表于2007-03-26 14:14:16  IP: 60.24.168.*

天啊!你太有才了@@@

 

#   http://www.csdn.net/ui/images/blank.gif  C#1983 发表于2007-03-26 14:19:44  IP: 221.219.6.*

向编码写作者 致敬 

 

#   http://www.csdn.net/ui/images/blank.gif  C#1983 发表于2007-03-26 14:22:09  IP: 221.219.6.*

向高手学习

 

#   http://www.csdn.net/ui/images/blank.gif  gehantao 发表于2007-03-26 14:31:48  IP: 210.77.134.*

受益了,收藏!

 

#   http://www.csdn.net/ui/images/blank.gif  Andy 发表于2007-03-26 14:41:58  IP: 218.59.67.*

数据读取却如此垃圾,海量数据试试

 

#   http://www.csdn.net/ui/images/blank.gif  ztchen 发表于2007-03-26 14:46:26  IP: 222.66.8.*

月儿辛苦,做得不错,继续努力吧,呵呵。

 

#   http://www.csdn.net/ui/images/blank.gif  spsx99vj 发表于2007-03-26 14:47:33  IP: 125.32.26.*

辛苦了,继续努力.

 

#   http://www.csdn.net/ui/images/blank.gif  21aspnet 发表于2007-03-26 14:56:33  IP: 220.234.107.*

海量数据读取用存储过程的,这样的存储过程很多啊,本文只是举例啊,你可以灵活应用啊。

 

#   http://www.csdn.net/ui/images/blank.gif  21aspnet 发表于2007-03-26 14:59:25  IP: 220.234.107.*

不过还是谢谢你提醒大家,大家如果有大量的数据用高效分页的存储过程等。这样更完美。

本文其实主要讲页面展现这个。

 

#   http://www.csdn.net/ui/images/blank.gif  sualang 发表于2007-03-26 15:01:48  IP: 58.217.175.*

# Andy 发表于2007-03-26 14:41:58 IP: 218.59.67.*
数据读取却如此垃圾,海量数据试试
===============================================

如果有几十万条数据你也一次都读出来?

无语!

 

#   http://www.csdn.net/ui/images/blank.gif  ditto 发表于2007-03-26 15:33:00  IP: 219.137.200.*

对于初学者,是比较好的入门指导

 

#   http://www.csdn.net/ui/images/blank.gif  coolyhtao 发表于2007-03-26 16:10:06  IP: 221.220.191.*

辛苦了,严重感谢

 

#   http://www.csdn.net/ui/images/blank.gif  yejianhua 发表于2007-03-26 20:00:32  IP: 61.183.172.*

索引超出范围。必须为非负值并小于集合大小。
参数名: index
string sqlstr = "update GridView set
姓名='" + ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',员工性别='" + ((TextBox)GridView1.Rows[e.RowIndex].Cells[2].Controls[0]).Text.ToString().Trim() + "',家庭住址='" + ((TextBox)GridView1.Rows[e.RowIndex].Cells[3].Controls[0]).Text.ToString().Trim() + "'where 身份证号码='" + GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
表结构
身份证号码 姓名 员工性别 家庭住址

 

#   http://www.csdn.net/ui/images/blank.gif  菜鸟 发表于2007-03-26 23:16:27  IP: 61.159.245.*

复杂表头的字段排序怎么做呀?

 

#   http://www.csdn.net/ui/images/blank.gif  foshan 发表于2007-03-27 08:28:35  IP: 218.13.85.*

谢谢!
用了 GridView固定表头 之后,表头各列的分隔线没有了,如何保留各列之间的分隔线啊???

 

#   http://www.csdn.net/ui/images/blank.gif  mingyueqingfeng 发表于2007-03-27 11:22:57  IP: 218.28.136.*

谢谢,学习中

 

#   http://www.csdn.net/ui/images/blank.gif  cyyu_ryh 发表于2007-03-27 11:43:50  IP: 222.177.14.*

强悍

 

#   http://www.csdn.net/ui/images/blank.gif  netharry 发表于2007-03-27 13:12:50  IP: 221.220.203.*

谢谢

 

#   http://www.csdn.net/ui/images/blank.gif  lpc444 发表于2007-03-27 13:15:17  IP: 59.34.101.*

很好!学习了。

 

#   http://www.csdn.net/ui/images/blank.gif  wl2000wh 发表于2007-03-27 13:33:16  IP: 219.134.236.*

只能是佩服啦!!!!!!!!!!!!!

 

#   http://www.csdn.net/ui/images/blank.gif  wjbo2006 发表于2007-03-27 16:57:06  IP: 222.66.84.*

Excel的时候,碰到数字的时候如果长度太大,需要加$
楼主好想没有注意到?1.0001E+1.7

 

#   http://www.csdn.net/ui/images/blank.gif  wjbo2006 发表于2007-03-27 16:57:55  IP: 222.66.84.*

学习了很多东西,非常感谢

 

#   http://www.csdn.net/ui/images/blank.gif  C 发表于2007-03-28 09:10:20  IP: 218.12.94.*

辛苦了

 

#   http://www.csdn.net/ui/images/blank.gif  pigmaster 发表于2007-03-28 10:12:01  IP: 218.249.35.*

不管数据提取,只需要这些技能就足够了

 

#   http://www.csdn.net/ui/images/blank.gif  kxm_168 发表于2007-03-28 15:32:26  IP: 61.232.2.*

楼主:B!!!!!

 

#   http://www.csdn.net/ui/images/blank.gif  webhermit 发表于2007-03-28 19:02:25  IP: 202.120.209.*

不顶不是人了!

 

#   http://www.csdn.net/ui/images/blank.gif  huahuahai 发表于2007-03-28 19:34:23  IP: 220.234.205.*

其实你的前两讲出来时我并没有觉得你有多厉害呢,现在才发现,真的是没话说。呵呵呵!!!

 

#   http://www.csdn.net/ui/images/blank.gif  ganlanshu_9447 发表于2007-03-29 10:29:34  IP: 210.83.223.*

好厉害呀

 

#   http://www.csdn.net/ui/images/blank.gif  qilinshu 发表于2007-03-29 16:06:01  IP: 211.144.104.*

首先要感谢楼主.但还是补充一下,楼主有些地方还是简略了些.例如第一个gridview无代码分页. 除了控件设置外,在代码中还是要写程序的,不然你除了第一页外其他页都无法显示.

 

#   http://www.csdn.net/ui/images/blank.gif  guest 发表于2007-03-30 09:55:59  IP: 221.219.118.*

感谢楼主!

 

#   http://www.csdn.net/ui/images/blank.gif  cainiao 发表于2007-03-30 10:24:37  IP: 222.172.147.*

讲讲 reporting service吧,密切关注

 

#   http://www.csdn.net/ui/images/blank.gif  sealeft 发表于2007-03-30 16:32:10  IP: 218.6.230.*

太高了
仰望

 

#   http://www.csdn.net/ui/images/blank.gif  liucan 发表于2007-04-02 11:23:43  IP: 218.18.115.*

O...8..顶了先....学习......有些人别太苛刻了....这些都是DEMO.学习学习..有足的大家都相互补充吗......你们能否写出来......没点职业精神.

 

#   http://www.csdn.net/ui/images/blank.gif  hu_bird 发表于2007-04-03 09:19:01  IP: 222.182.95.*

高手阿,楼主辛苦了。至于海量数据就没有必要较真,至少对我这种初学者来说已经够用了,如果搞得太复杂了反而让菜鸟看不懂了。

 

#   http://www.csdn.net/ui/images/blank.gif  zhang 发表于2007-04-03 19:07:02  IP: 124.114.131.*

xiexie

 

#   http://www.csdn.net/ui/images/blank.gif  wqm_44944 发表于2007-04-05 13:24:08  IP: 60.216.11.*

谢谢

 

#   http://www.csdn.net/ui/images/blank.gif  read 发表于2007-04-05 15:42:24  IP: 222.92.4.*

非常的好,有貢獻精神。。
敬佩

 

#   http://www.csdn.net/ui/images/blank.gif  zhengmx 发表于2007-04-07 13:46:31  IP: 59.34.18.*

好东西啊,学习了...

 

#   http://www.csdn.net/ui/images/blank.gif  zhengmx 发表于2007-04-07 13:48:35  IP: 59.34.18.*

楼主这里.net的资料很全面啊...呵呵,看来以后要多来学习了....

 

#   http://www.csdn.net/ui/images/blank.gif  systemLife 发表于2007-04-10 15:45:16  IP: 211.140.202.*

我对你的景仰有如滔滔江水,连绵不绝......

 

#   http://www.csdn.net/ui/images/blank.gif  qy3730201 发表于2007-04-11 10:52:09  IP: 202.103.49.*

您太有才了~~~~~

 

#   http://www.csdn.net/ui/images/blank.gif  Animatrix 发表于2007-04-11 16:02:08  IP: 210.22.108.*

13.GridView弹出新页面/弹出制定大小位置新窗口:
这一段里面的第2种方法好象不行。呵呵,GRIDVIEW里好象没HyperLinkColumn吧?

 

#   LOVE&gt;&gt;.NET 发表于2007-04-11 16:43:03  IP: 58.63.47.*

太好了,谢谢你为我们的付出,谢谢啊!

 

#   http://www.csdn.net/ui/images/blank.gif  Small_Huge 发表于2007-04-12 12:44:25  IP: 221.221.39.*

向高手致敬!!!!!!!!

 

#   http://www.csdn.net/ui/images/blank.gif  skunk 发表于2007-04-12 16:16:18  IP: 219.149.220.*

谢谢

 

#   http://www.csdn.net/ui/images/blank.gif  Mark 发表于2007-04-18 02:35:16  IP: 125.171.133.*

导出EXCL那段代码提示 当前上下文中不存在名称“Encoding”

忘解答maihuasen@163.com

 

#   http://www.csdn.net/ui/images/blank.gif  青春发梢 发表于2007-04-18 09:45:11  IP: 125.123.72.*

高手,菜鸟向你致敬

 

#   http://www.csdn.net/ui/images/blank.gif  过客 发表于2007-04-18 21:10:08  IP: 58.49.64.*

不的不顶呀!我汗!!!厉害!

 

#   http://www.csdn.net/ui/images/blank.gif  学习中  发表于2007-04-19 08:45:50  IP: 59.191.125.*

感谢分享,本人收藏了!希望写出更多的文章!

 

#   http://www.csdn.net/ui/images/blank.gif  无名 发表于2007-04-20 16:56:09  IP: 121.34.155.*

谢谢.............我是初学,,,,,看了这些让我有了新的认识!

 

#   http://www.csdn.net/ui/images/blank.gif  zp89850 发表于2007-04-20 17:45:01  IP: 221.122.59.*

看完后 感觉不说声谢谢心里像少点什么似的。
多谢阿,

 

#   http://www.csdn.net/ui/images/blank.gif  无名 发表于2007-04-21 00:17:21  IP: 121.34.153.*

看了这些技巧,我很感谢楼主.

在测试的过程中发现个问题想请教下:
在这一项里面:
2.GridView
选中,编辑,取消,删除:
:
用户编号 用户类型 审核状态 推荐排名 编辑
2001
普通个人会员 已审核 1 编辑
2003
普通个人会员 已审核 2 编辑
1020
普通个人会员 已审核 3 编辑

这是:点击"编辑"后的
用户编号 用户类型 审核状态 推荐排名 编辑
2001
普通个人会员 已审核 1 更新 取消
2003
普通个人会员 已审核 2 更新 取消
1020
普通个人会员 已审核 3 更新 取消

这里是原始值
推荐排名
3
当我改成300,,,点击更新.....但程序里面的:

protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
Response.Write(((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[6].Controls[0])).Text.ToString().Trim());
Response.End();
}
输出的值还是3而不是我改后的300....不知道是什么原因,还请赐教...谢谢


    

2007-04-21 01:16:02作者回复:
你理解似乎有问题 你点击更新以后并未做更新页面postback马上就刷回去了,所以必须更新后存数据库里。因为页面是服务器端事件,如果javascript事件就可。

 

 

#   http://www.csdn.net/ui/images/blank.gif  无名:更正以上代码::::: 发表于2007-04-21 10:24:10  IP: 121.34.153.*

protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
Response.Write(((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim());
Response.End();
}

 

#   http://www.csdn.net/ui/images/blank.gif  无名:那我该怎么解决这个问题呢发表于2007-04-21 10:26:50  IP: 121.34.153.*

2007-04-21 01:16:02作者回复:
你理解似乎有问题 你点击更新以后并未做更新页面postback马上就刷回去了,所以必须更新后存数据库里。因为页面是服务器端事件,如果javascript事件就可。


我该怎么写.........谢谢...

 

#   http://www.csdn.net/ui/images/blank.gif  无名:那我该怎么解决这个问题呢?  发表于2007-04-21 10:35:09  IP: 121.34.153.*

我的程序如下:
后台代码:
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
Response.Write(((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[6].Controls[0])).Text.ToString().Trim());
Response.End();
IMYSUN.UserEditInfo useredit = new IMYSUN.UserEditInfo();
useredit.Sorts = ((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[6].Controls[0])).Text.ToString().Trim();
useredit.Email = GridViewUser.DataKeys[e.RowIndex].Value.ToString();
useredit.addType = "edit";
IMYSUN.IMYSUN usedit = new IMYSUN.IMYSUN();

usedit.UserEdit(useredit);
GridViewUser.EditIndex = -1;
this.Get_AllUser();}


/// </summary>
public class UserEditInfo
{
public string Email;
public string UserNO;
public string Sorts;
public string UserName;
public string About;
public string addType;
}



/// <summary>
///
编辑用户
/// </summary>
/// <param name="UserID"></param>
public void UserEdit(UserEditInfo user)
{
///
定义类SQLHelper
SQLHelper.SQLHelper sqlHelper = new SQLHelper.SQLHelper();
//user.Sorts=Convert(int,(user.Sorts));
///
创建访问数

 

#   http://www.csdn.net/ui/images/blank.gif  无名:那我该怎么解决这个问题呢? :::: 发表于2007-04-21 10:38:06  IP: 121.34.153.*

/// <summary>
///
编辑用户
/// </summary>
/// <param name="UserID"></param>
public void UserEdit(UserEditInfo user)
{
///
定义类SQLHelper
SQLHelper.SQLHelper sqlHelper = new SQLHelper.SQLHelper();
//user.Sorts=Convert(int,(user.Sorts));
///
创建访问数据库的参数
SqlParameter[] paramList =
{
sqlHelper.CreateInParam("@addType", SqlDbType.Char,10,user.addType),
sqlHelper.CreateInParam("@Email", SqlDbType.NVarChar,50,user.Email),
//sqlHelper.CreateInParam("@UserName", SqlDbType.NVarChar,50,user.UserName),
//sqlHelper.CreateInParam("@About", SqlDbType.VarChar,5000,user.About),
sqlHelper.CreateInParam("@Sorts", SqlDbType.Int,4,user.Sorts)
};

try
{
///
执行存储过程
sqlHelper.RunProc("UserEdit", paramList);
}
catch (Exception ex)
{
///
抛出执行数据库异常
SystemError.CreateErrorLog(ex.Message);
throw new Exception(ex.Message, ex);

}
finally
{
sqlHelper.Close();
}
}
存储过程:
CREATE PROCEDURE UserEd

 

#   http://www.csdn.net/ui/images/blank.gif  无名:那我该怎么解决这个问题呢? :::: 发表于2007-04-21 10:38:59  IP: 121.34.153.*

CREATE PROCEDURE UserEdit
(
@addType char(10),
@Email nvarchar(50),
@Sorts int
)
AS
BEGIN
DECLARE @UserID nvarchar(50)
SELECT @UserID=UserID
FROM [User]
WHERE Email=@Email

UPDATE [UserInfo] SET Sorts=8000 WHERE Sorts=@Sorts
UPDATE [UserInfo] SET Sorts=@Sorts
WHERE UserID=@UserID
END
GO

谢谢..........

 

#   http://www.csdn.net/ui/images/blank.gif   发表于2007-04-21 11:38:57  IP: 202.167.248.*

(((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[6].Controls[0])).
=======================
(((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[6].Controls[0])).
(((TextBox)(GridViewUser.Rows[e.RowIndex].Cells[6].Controls[1])).
对应不同的

 

#    发表于2007-04-21 11:40:23  IP: 202.167.248.*

那我该怎么解决这个问题呢
================
//
更新
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
sqlcon = new SqlConnection(strCon);
string sqlstr = "update
set 字段1='"
+ ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim() + "',
字段2='"
+ ((TextBox)(GridView1.Rows[e.RowIndex].Cells[2].Controls[0])).Text.ToString().Trim() + "',
字段3='"
+ ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim() + "' where id='"
+ GridView1.DataKeys[e.RowIndex].Value.ToString() + "'";
sqlcom=new SqlCommand(sqlstr,sqlcon);
sqlcon.Open();
sqlcom.ExecuteNonQuery();
sqlcon.Close();
GridView1.EditIndex = -1;
bind();
}

 

#   http://www.csdn.net/ui/images/blank.gif  无名::::::,我的问题还是没解答...清楚...呵呵... 发表于2007-04-23 09:47:25  IP: 121.35.48.*

郁闷..................

 

#   http://www.csdn.net/ui/images/blank.gif  无名::::::,我的问题还是没解答...清楚...呵呵... 发表于2007-04-23 09:49:01  IP: 121.35.48.*

按你的那种方式执行SQL语句也是一样的,,,不能更新........


    

2007-04-23 21:04:08作者回复:
#
无名::::::,我的问题还是没解答...清楚...呵呵... 发表于2007-04-23 09:47:25 IP: 121.35.48.*<br />郁闷..................<br /><br /><br /># 无名::::::,我的问题还是没解答...清楚...呵呵... 发表于2007-04-23 09:49:01 IP: 121.35.48.*<br />按你的那种方式执行SQL语句也是一样的,,,不能更新........<br />==================<br /><br />我的代码绝对没有问题,你注意看杨婉君被改为杨婉君1”<br />2.GridView选中,编辑,取消,删除: 杨婉君<br /><br />3.GridView正反双向排序: 杨婉君1<br /><br />你先把我的代码全部拷贝过去绝对可以改,一定是你哪里有问题。<br /><br />我学习别人代码的方法是先全拷贝,再改我的!<br /><br />学习要善于发现问题。不断推敲,逐步逼近结果。你要动脑筋啊。<br /><br /><br />还有个问题 就是“SQLhelper”如果你的sql语句有错他不报错但是也不执行!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!<br /><br />所以你要把你的纯sql拿到sqlerver2005里执行一次 一定有问题!!!!!!!!!!!!!!!!!<br /><br />编程也和破案子一样啊!!!!!!!!!!!!!!!!<br /><br />还有你主键设了么 等等 都要考虑的。

 

 

#   http://www.csdn.net/ui/images/blank.gif   发表于2007-04-26 15:04:00  IP: 222.169.19.*

有没有用VB.NET实现的..VRIDVIEW 控制真麻烦啊

 

#   http://www.csdn.net/ui/images/blank.gif   发表于2007-04-26 15:07:12  IP: 222.169.19.*

有没有用VB.NET实现的..VRIDVIEW 控制真麻烦啊

 

#   http://www.csdn.net/ui/images/blank.gif  teachman_999 发表于2007-04-27 15:15:30  IP: 202.64.67.*

to 版主:

在更新时,以下语句
((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim()

读出来的还是原有值

 

#   http://www.csdn.net/ui/images/blank.gif  john_huang 发表于2007-04-28 21:15:17  IP: 222.191.242.*

不顶以后不要上CSDN

 

#   http://www.csdn.net/ui/images/blank.gif  深蓝 发表于2007-04-29 09:12:45  IP: 58.49.225.*

没一点技术含量的垃圾代码拿出来献丑也就算了,还什么C#精髓,真是笑煞旁人!

虽然GridView没有规定使用的人,但你这样的人使用就是对它的侮辱。asp.net的开发者们知道你这样的使用他们辛苦开发的成果又是如何作想呢?本来你是人渣也好败类也罢这都没有关系,但是你这种人也能使用神殿里的圣卷,那就是全人类的悲哀。

猪也这种动物不是天生可耻,相反的还相当之可爱,但是一只会说话的猪在这里嗷嗷学语,还学人话在这里大放厥词,还在这里像教师那样教别人,这就是你的不对了,你把别人都当成你的同类吗?
CSDN
软体开发者的圣殿也放了你这种连猪都不是的什么进来。这点就有点奇怪了!

----------------------------
骂完分隔线---------------------------

GridView
可以说是.net开发人员必用的控件之一,但有几个正常点的开发人员会像你这样用:

1
。不做任何处理,刷一下把所有数据读到前台,你想服务器死还是你死呀?
2
。 数据本身不作任何处理直接绑,你也要别人学你这样吗?误人子弟
3
。所有代码居然全在服务器端处理。最可笑的是行变色代码。你没看过猪走也吃过猪肉好不好,多看下别人的网站,不是看源码,而是直接打开HTML前端看别人写的,有几个不是直接在页面处理table的显示的。你知道不知道什么MVCView层的ManageClass是作什么用的?是你用来操作这种所谓的网页特效的吗?
4
。不说既是讲课,没有半行注释,就是平时写代码不作注释也直接被人以垃圾扔了,没有注释的代码在白测人员的眼里就是有缺陷的代码,这种代码你得重写,跟这种代码一同保存在VSS上的同仁一定会羞愧的想自杀。当然那种连CMMI2都没有的小公司就别论!

 

#   http://www.csdn.net/ui/images/blank.gif  bczy 发表于2007-04-29 10:30:05  IP: 221.197.35.*

太棒了,受益匪浅

 

#   http://www.csdn.net/ui/images/blank.gif  shuiyin999 发表于2007-04-29 14:49:24  IP: 220.231.157.*

不错

 

#   http://www.csdn.net/ui/images/blank.gif  gejunlin 发表于2007-04-29 19:39:57  IP: 222.212.8.*

高手呀~强汗。我正在为这个控件犯愁呢。谢谢,谢谢。再次谢谢~

 

#   http://www.csdn.net/ui/images/blank.gif  flyfish 发表于2007-05-03 21:53:14  IP: 58.51.64.*

谢谢您,高手!向你致敬,多写些图文并茂的东西出来回报社会!

 

#   http://www.csdn.net/ui/images/blank.gif  flyandgoing 发表于2007-05-05 14:31:20  IP: 218.12.45.*

真好

 

#   http://www.csdn.net/ui/images/blank.gif  MRPETERHXY 发表于2007-05-11 10:46:57  IP: 59.41.216.*

技术是过硬的,不过代码全部写在服务器端,真不是一件很好的事。

 

#   http://www.csdn.net/ui/images/blank.gif  fdzxlg 发表于2007-05-14 14:32:13  IP: 124.21.205.*

能磊出这么多代码出来,一名话:辛苦了!

 

#   http://www.csdn.net/ui/images/blank.gif  lgz_1205 发表于2007-05-17 17:13:59  IP: 221.219.24.*

LZ,你辛苦了!

 

#   http://www.csdn.net/ui/images/blank.gif  netharry 发表于2007-05-17 20:07:35  IP: 125.34.159.*

多谢楼主

 

#   http://www.csdn.net/ui/images/blank.gif  piscailei 发表于2007-05-18 16:30:41  IP: 222.183.142.*

辛苦了

 

#   http://www.csdn.net/ui/images/blank.gif  axe 发表于2007-05-18 16:51:29  IP: 210.78.63.*

象这样的乐于助人的人太少拉,所以我除了顶还是顶!

 

#   http://www.csdn.net/ui/images/blank.gif  hitspeed 发表于2007-05-19 14:02:23  IP: 211.93.58.*

哈哈,深蓝的一翻言论不得不顶啊,感同身受

 

#   http://www.csdn.net/ui/images/blank.gif  bearhunter 发表于2007-05-19 19:00:46  IP: 125.115.13.*

学习

 

#   http://www.csdn.net/ui/images/blank.gif  boy2007 发表于2007-05-19 21:46:43  IP: 121.69.138.*

高手,继续努力。

 

#   http://www.csdn.net/ui/images/blank.gif  Genius1218 发表于2007-05-21 15:42:16  IP: 210.14.75.*

楼主小心你强死了

 

#   http://www.csdn.net/ui/images/blank.gif  abest 发表于2007-05-22 11:44:32  IP: 221.224.120.*

问一个问题:
我用Gridview绑定一个List泛型的数据源,然后GridView的列标题就是英文,我现在想改为中文怎么办?还要求可以排序!
另外,不能前台里面写代码,前台只能放一个GridView,然后所有的代码都在后台做,因为我还想重用这些代码。谢谢!
如果您方便的话,发到我信箱里:Abest_000@126.com

 

#   http://www.csdn.net/ui/images/blank.gif  我是谁 发表于2007-05-22 18:06:27  IP: 59.63.36.*

在更新时,以下语句
((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim()

读出来的还是原有值


我也遇到同样的问题,希望版主能尽快解决呀
偶将不甚感激。。。。

 

#   http://www.csdn.net/ui/images/blank.gif  hai173 发表于2007-05-23 10:12:30  IP: 125.33.157.*

我想问一个GridView正反双向排序的问题 我是按着你的写的 但是显示不出来 代码你看一下哪有问题
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;
using System.Data.SqlClient;
public partial class Default3 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ViewState("SortOrder") = "ProductID";
ViewState["OrderDire"] = "ASC";
bind();
}
}

public void bind()
{
string strconn = "server = .;database = Northwind;uid = sa;pwd = sa";
string strda = "select * from Products";
SqlConnection conn = new SqlConnection(strconn);
SqlDataAdapter da = new SqlDataAdapter(strda, conn);
DataSet ds = new DataSet();
da.Fill(ds, "Products");
DataView view = ds.Tables["Products"].DefaultView;
string sort = (string)ViewState["SortOrder"] + " " + (string)ViewState["OrderDire"];
view.Sort = sort;
GridView1.DataSource = view;
GridView1.DataBind();

}
protected void GridView1_Sorting(object sender, GridViewSortEventArgs

 

#   http://www.csdn.net/ui/images/blank.gif  OGLD3D 发表于2007-05-23 17:18:06  IP: 218.65.61.*

真是高手呀,厉害的不得了。不过我想知道,如何能实现既要分页,又要进行编辑删除的GridView。因为绑定的时候,要进行分页,就不能用if(!IsPostBack),而要编辑,则必须用if(!IsPostBack)。如何让二者兼得呢?请赐教!

 

#   http://www.csdn.net/ui/images/blank.gif  ElandYang 发表于2007-05-24 11:08:34  IP: 222.92.144.*

鼠标移到GridView某一行时改变该行的背景色方法一:
for (i = 0; i < GridView1.Rows.Count; i++)
应该改为:
for (i = 0; i <=GridView1.Rows.Count; i++)
否则第一条记录不会改变颜色!

感谢楼主的资料!

 

这篇关于GridView72绝技的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/805256

相关文章

游泳训练用水下耳机哪款好?6个挑选绝技汇总,教你选对游泳耳机

在游泳训练中,一款优质的水下耳机不仅能让你在水中畅享音乐,更能提升训练效果,增添运动的乐趣。然而,市面上的游泳耳机种类繁多,如何挑选一款既适合游泳训练又具备优质音质的耳机,成为了许多游泳爱好者的难题。 (以上是之前测试过的其他游泳耳机) 今天,我们将为大家揭示六个挑选游泳耳机的绝技,并推荐四款备受好评的游泳耳机,帮助你轻松选对适合自己的水下伴侣。 1. 耐用性——要有抗衰减性能设计

万字长文带你掌握 IDEA 2024 的30个Debug调试绝技,让你开发与修复 Bug 的效率提升亿倍

万字长文带你掌握 IDEA 2024 的30个Debug调试绝技,让你开发与修复 Bug 的效率提升亿倍 博主猫头虎的技术世界 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能! 专栏链接: 🔗 精选专栏: 《面试题大全》 — 面试准备的宝典!《IDEA开发秘籍》 — 提升你的IDEA技能!《100天精通鸿蒙》 — 从Web/安卓到鸿蒙大师!《100天精通Golang(基础入门篇

C#精髓-- GridView 72般绝技

#精髓-- GridView 72般绝技 转自:http://blog.csdn.net/lbh9158/archive/2007/06/04/1637002.aspx   快速预览: GridView无代码分页排序 GridView选中,编辑,取消,删除 GridView正反双向排序 GridView和下拉菜单DropDownList结合 GridView和CheckBox结合 鼠

必备绝技--Hook大法( 上 )

【文章标题】: 必备绝技--Hook大法(上) 【文章作者】: LvG 【作者邮箱】:  LvG2008@gmail.com 【作者声明】: 这没有什么新鲜东西,其内容全部来自于前辈,姑且当作学习笔记。文字用自己的话写出,四段代码均出自别人(知道作者的,以注明),但短小精悍,就写在一起了,便于察看。欢迎指正。 ---------------------------------------

备绝技——hook大法( 中 )

必备绝技——hook大法( 中 ) 标 题: 【原创】必备绝技——hook大法( 中 ) 作 者: Lvg时 间: 2007-04-09,23:37链 接: http://bbs.pediy.com/showthread.php?threadid=42422 【文章标题】: 必备绝技——hook大法( 中 ) 【文章作者】: LvG 【作者邮箱】:  LvG2008@g

缓存修炼手册:跟着我走进分布式缓存的神秘世界,解密缓存雪崩、缓存穿透等技术难题。发掘缓存预热、更新、降级的独门绝技,让你在面试中轻松秒杀

1. 分布式缓存概念 分布式缓存是一种用于存储和管理数据的系统,它将数据缓存在多个节点上,以提高性能和可扩展性。以下是分布式缓存的一些关键概念和特点: 缓存节点: 分布式缓存系统由多个节点组成,每个节点负责存储一部分数据。这些节点可以分布在不同的物理服务器上,形成一个缓存集群。 数据分片: 缓存中的数据被划分为多个分片,每个分片由不同的缓存节点管理。数据的分片可以根据某种策略(例如

20天赚46%最牛私募解密短线绝技

核心提示:成绩如此出色,少年私募英雄杨永兴究竟掌握了什么制胜法宝?4月2日,《每日经济新闻》专访了策略大师基金的管理团队,证通天下董事长杨永兴、证通天下总经理李世勇(以下统称为"策略大师")向记者透露了他们的宝贵经验。在股市中把600万元变成一个亿,需要多少时间?有人会说5年、10年,也许更长,但有人只花了10个月在2007年朝阳永续的实盘大赛中,硅谷基金的投资经理杨永兴以高达1497%的收益率,

【HarmonyOS】六脉神剑 | 元服务绝技之卡片刷新

【关键字】 元服务卡片(简称卡片)、刷新 【背景介绍】 本文主要介绍元服务卡片(简称卡片)中Java卡片的刷新相关知识,首先我们需要对卡片中的角色有基本的了解,如下: 1、卡片提供方 提供卡片显示内容的HarmonyOS应用或原子化服务,控制卡片的显示内容、控件布局以及控件点击事件。 2、卡片使用方 显示卡片内容的宿主应用,控制卡片在宿主中展示的位置,最常见的使用方如:桌面、服务

golang快速入门[7.2]-北冥神功—go module绝技

前文 golang快速入门[1]-go语言导论golang快速入门[2.1]-go语言开发环境配置-windowsgolang快速入门[2.2]-go语言开发环境配置-macOSgolang快速入门[2.3]-go语言开发环境配置-linuxgolang快速入门[3]-go语言helloworldgolang快速入门[4]-go语言如何编译为机器码golang快速入门[5.1]-go语言是如何运

网站引流绝技:如何通过外链持续给网站带来高质量流量

做网站的人,不论是写文章还是搞外链,最终都是希望能获得更多的流量。既然是为了搞来流量和收入,你可能还不知道有一种方法既能搞来外链还能带来源源不断的高质量流量。 这个方法我在8年前就已经掌握,而且至今我仍认为它是一种有效的手段。最近,我在制作公司内部的SEO教程时,也强烈推荐了这种方法,让全球的同事们也能从中受益。当然,我公司的官网动态和公众号也不能错过! 我针对中文和英文都搜了一遍外链引流及引