日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[转]GridView 72般绝技

發布時間:2024/9/5 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [转]GridView 72般绝技 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

快速預覽:
GridView無代碼分頁排序
GridView選中,編輯,取消,刪除
GridView正反雙向排序
GridView和下拉菜單DropDownList結合
GridView和CheckBox結合
鼠標移到GridView某一行時改變該行的背景色方法一
鼠標移到GridView某一行時改變該行的背景色方法二
GridView實現刪除時彈出確認對話框
GridView實現自動編號
GridView實現自定義時間貨幣等字符串格式
GridView實現用“...”代替超長字符串
GridView一般換行與強制換行
GridView顯示隱藏某一列
GridView彈出新頁面/彈出新窗口
GridView固定表頭(不用javascript只用CSS,2行代碼,很好用)
GridView合并表頭多重表頭無錯完美版(以合并3列3行舉例)
GridView突出顯示某一單元格(例如金額低于多少,分數不及格等)
GridView加入自動求和求平均值小計
GridView數據導入Excel/Excel數據讀入GridView

1.GridView無代碼分頁排序

效果圖:

1.AllowSorting設為True,aspx代碼中是AllowSorting="True";
2.默認1頁10條,如果要修改每頁條數,修改PageSize即可,在aspx代碼中是PageSize="12"。
3.默認的是單向排序的,右擊GridView彈出“屬性”,選擇AllowSorting為True即可。


2.GridView選中,編輯,取消,刪除:

效果圖:

后臺代碼:
你可以使用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次的排序,點其他也一樣可以。

后臺代碼:
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"] = "Desc";
??????? }
??????? 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結合:

效果圖:

后臺代碼:
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.GridView和CheckBox結合:

效果圖:

后臺代碼:

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某一行時改變該行的背景色方法一:

效果圖:

做法:
雙擊GridView的OnRowDataBound事件;
在后臺的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某一行時改變該行的背景色方法二:

效果圖:

做法:和上面的一樣就是代碼不同
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實現刪除時彈出確認對話框:

效果圖:

實現方法:
雙擊GridView的OnRowDataBound事件;
在后臺的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實現自動編號:

效果圖:

實現方法:
雙擊GridView的OnRowDataBound事件;
在后臺的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-未格式化前

圖2-格式化后

解決方法:

在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實現用“...”代替超長字符串:

效果圖:

解決方法:數據綁定后過濾每一行即可
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一般換行與強制換行:

效果圖:

首先設置<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();//調用數據綁定即可
??????? }
??? }
總之:善用CSS的word-break:break-all;word-wrap:break-word屬性即可,這個屬性是通用的對于頑固的南換行問題都可以解決,不局限于GridView。

?12.GridView顯示隱藏某一列:
本方案為月兒獨創,不同于網上其他方式,我覺得用一個CheckBox更人性化,這樣可以隱藏不必要的列,讓用戶自己選擇需要出現的列,在處理多列時這是一個很好的解決方案!

效果圖:
圖1-開始

圖2-點擊顯示的CheckBox后

解決方案:
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());
??? }

注意:CheckBox1的AutoPostBack要True

后臺全部代碼如下:

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彈出新頁面/彈出制定大小位置新窗口:

效果圖:

方案一:簡單的方法,新窗口不固定大小
?<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>

使用的是結合javascript的window.open方法,關于window.open的參數網上有很多帖子,本站也有許多參考
彈出窗口大全 http://blog.csdn.net/21aspnet/archive/2004/10/25/150231.aspx?? 即可!

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

效果圖:

代碼:
<!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設如上的樣式,HeaderStyle加CssClass="Freezing,套住GridView的Div設置高度寬度 <div style="overflow-y: scroll; height: 200px;width:200px" >

15.GridView合并表頭多重表頭無錯完美版(以合并3列3行舉例)

效果圖:


后臺代碼:
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突出顯示某一單元格(例如金額低于多少,分數不及格等)

效果圖:

解決方案:主要是綁定后過濾
?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加入自動求和求平均值小計

效果圖:
解決方案:????
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

效果圖:

解決方案:
頁面增加一個按鈕,單擊事件添加如下方法:
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)
??? {
??? }
還有由于是文件操作所以要引入名稱空間IO和Text

后臺代碼:
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();
??? }

轉載于:https://www.cnblogs.com/scgw/archive/2007/08/11/851661.html

總結

以上是生活随笔為你收集整理的[转]GridView 72般绝技的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

伊人色播| 天天综合久久 | 精品久久久久久久 | 国产区精品在线观看 | 日韩电影在线看 | 亚洲永久精品在线 | 亚洲成 人精品 | 久草观看视频 | 看v片 | 亚洲一区二区精品3399 | 日韩欧美一区二区三区免费观看 | 中文字幕免费高清在线 | 国产区精品在线观看 | 免费在线色电影 | 国产剧情久久 | 99精品久久久久久久 | 日韩网站在线播放 | 欧美一区二区三区在线 | www91在线| 色香蕉在线 | 四虎国产永久在线精品 | 日本精品二区 | 成人a免费 | 91久久黄色 | 亚洲精品久久久久58 | 国产va在线 | 亚洲成av人片在线观看无 | 中文字幕免费看 | 国产精品视频专区 | 亚洲精品中文字幕在线观看 | 狠狠干夜夜 | 91观看视频 | 国产亚洲精品xxoo | 国产 欧美 在线 | 午夜精品久久久久久久久久久 | 精品电影一区 | 日韩中文字幕免费在线观看 | 免费视频区 | 免费av电影网站 | av综合av| 2024国产精品视频 | 亚洲欧美成人在线 | 在线观看福利网站 | 亚洲美女精品区人人人人 | 91大神dom调教在线观看 | 日韩中文字幕免费在线观看 | 国产69精品久久久久久久久久 | 婷婷中文字幕综合 | 麻豆传媒在线免费看 | 亚洲国产精彩中文乱码av | 黄色软件网站在线观看 | 97看片| 亚洲精品美女久久17c | 国产午夜精品一区二区三区在线观看 | 欧美日韩国内在线 | 久久激情视频 久久 | 日本精品久久久久影院 | 9999在线观看 | 日韩精品一卡 | 97超碰在线资源 | 最新日韩视频在线观看 | 国产精品视频免费 | 日韩专区av | h网站免费在线观看 | 久久国产精品影视 | 日韩精品专区在线影院重磅 | 久草在线在线视频 | 色偷偷男人的天堂av | 丁香视频全集免费观看 | 欧美人人| 亚洲精品日韩在线观看 | 中文字幕文字幕一区二区 | 色999五月色| 一区二区三区免费在线播放 | 狠狠精品 | 啪啪凸凸| 亚州精品国产 | 六月色婷婷| 人人射人人爽 | 日韩欧美一级二级 | 国产成人精品午夜在线播放 | 国产成人一区二区三区电影 | 一区在线观看 | 成人免费视频在线观看 | 成人小视频在线观看免费 | 亚洲精品视频在线播放 | 91中文字幕网 | 一区二区三区四区免费视频 | 亚洲天堂香蕉 | 天天狠狠干 | 国产视频一区在线 | 精品久久久免费视频 | 精品国产人成亚洲区 | 亚洲免费高清视频 | 黄色动态图xx | 国产一级在线视频 | 91亚洲精品久久久蜜桃 | 午夜日b视频| 日韩精品免费在线观看视频 | 精品国产成人av | www天天干 | 久久伊人综合 | 五月天免费网站 | 一区三区视频在线观看 | 黄色影院在线播放 | 中文字幕婷婷 | 国产福利不卡视频 | 西西www4444大胆在线 | 国产在线第三页 | 91精品国产91热久久久做人人 | 国产一区二区视频在线 | 久久九九免费 | 国产精品女同一区二区三区久久夜 | av一区二区三区在线播放 | 久久首页| 国产中的精品av小宝探花 | 激情网婷婷 | 在线国产小视频 | 亚州精品一二三区 | 日韩成人精品一区二区 | 成人免费视频网站 | 手机成人在线 | 亚洲国产精品va在线看黑人动漫 | 国产日韩欧美在线看 | 99久精品 | av在线网站免费观看 | 香蕉视频国产在线观看 | 国产黄a三级三级 | 麻花豆传媒mv在线观看网站 | 韩国一区在线 | 天天摸天天操天天舔 | 男女拍拍免费视频 | 国产精品成人一区二区三区吃奶 | 99视频在线精品免费观看2 | 91亚洲网 | 久久久资源 | 国产一级淫片在线观看 | www.日本色 | 国产成人精品一区二区三区福利 | 国产一级大片在线观看 | 在线观看免费国产小视频 | 国产美女视频网站 | 久久夜色电影 | 奇米影音四色 | 99视频这里只有 | 日韩欧美一区二区三区视频 | 日韩偷拍精品 | 正在播放日韩 | 天天操天天干天天摸 | 色香蕉视频| 国产精品嫩草影视久久久 | 午夜精品视频在线 | a在线免费观看视频 | 九九精品久久久 | 亚洲h色精品 | 亚洲欧美国内爽妇网 | 日韩欧美综合在线视频 | 久久 精品一区 | 久久综合久久综合久久 | aaa亚洲精品一二三区 | 人人舔人人干 | 国产精品丝袜久久久久久久不卡 | 久久婷婷网 | 综合国产在线 | 国产一级大片在线观看 | 久久人人爽人人 | 婷婷色六月天 | 久久国产三级 | 婷婷丁香花五月天 | 一区二区三区动漫 | 99热这里只有精品免费 | bbw av | 草久草久 | 国产亚洲精品v | 粉嫩av一区二区三区四区在线观看 | 久草在线最新免费 | 天天色天天操综合网 | 国产精品18久久久久vr手机版特色 | 久久精品视频在线看 | 久久五月婷婷丁香社区 | 最近中文字幕大全中文字幕免费 | aaaaaa毛片| 五月婷婷六月丁香 | 日韩免费区 | 91在线最新 | 久草视频在线资源 | 日韩精品视频第一页 | 国内精品小视频 | 婷婷色网视频在线播放 | 色狠狠综合天天综合综合 | 精品国产免费人成在线观看 | 国产成人精品免费在线观看 | 在线欧美小视频 | 久久精品一区 | 最近最新中文字幕 | 久久午夜精品影院一区 | 亚洲精品在线一区二区三区 | 九九久久影视 | 91免费的视频在线播放 | 99久久精品免费视频 | 亚洲在线精品 | 97视频精品 | 免费观看日韩 | 国产免费观看久久 | 久久国产网| 日韩免费一级a毛片在线播放一级 | 久久尤物电影视频在线观看 | 在线影院av | 久久免费在线视频 | 又黄又爽又色无遮挡免费 | 99免费在线播放99久久免费 | 国产96av | 一区二区三区av在线 | 91精品播放 | 最新中文字幕视频 | 国产亚洲精品bv在线观看 | 国产视频在| 91精品国产自产在线观看 | 精品一区精品二区高清 | 日韩高清av在线 | 天天激情站 | 操高跟美女 | va视频在线观看 | 国产一区久久 | 91丨九色丨高潮 | 国产高h视频 | 国产成人精品一区一区一区 | 精品嫩模福利一区二区蜜臀 | 欧美婷婷色 | 亚洲乱码精品久久久久 | 欧美在线观看视频一区二区 | 欧美一级视频在线观看 | 99视频一区 | 久久久久久欧美二区电影网 | 精品久久精品久久 | 手机av网站| 久久久久成人精品免费播放动漫 | 玖玖在线精品 | 激情婷婷综合网 | 日韩av免费在线看 | a级成人毛片 | 四虎成人精品永久免费av | 亚洲男男gaygay无套同网址 | 中文字幕第一页在线vr | 亚洲人片在线观看 | 国内精品久久久久久久97牛牛 | 国产精品嫩草影视久久久 | 国产v欧美| 久久免费精品视频 | 最近中文字幕免费观看 | 久久久国产精品视频 | 国产成人av电影在线 | 中文一区二区三区在线观看 | 国产免费一区二区三区最新 | 九九精品久久久 | 国产中文在线字幕 | 91精品福利在线 | 青青河边草免费 | 久久tv视频 | 国产一区二区三区免费在线 | 91av手机在线 | 久久久国产精品人人片99精片欧美一 | 超碰在线最新地址 | 国产一区在线播放 | 天天干天天干天天色 | 婷婷.com| 久草网视频 | 麻花豆传媒mv在线观看网站 | 日日夜夜狠狠干 | 精品视频免费在线 | 日韩有码中文字幕在线 | 麻豆免费视频网站 | 欧美日韩一区二区三区在线免费观看 | 国产真实在线 | 国产精品九九视频 | 日韩视频精品在线 | 中文字幕在线看视频 | 探花视频网站 | 成人国产精品久久久久久亚洲 | 久久久久黄 | 亚洲激情在线观看 | 精品自拍av | 日韩在线视 | 日韩免费一区 | 亚洲国产中文字幕在线 | 中文字幕免费播放 | 国产一区二区精品在线 | 国产黄色一级片在线 | 亚洲精品午夜aaa久久久 | 人人爽爽人人 | 久艹视频在线免费观看 | 黄色1级毛片 | 国产美女黄网站免费 | 在线色吧 | 亚洲乱码在线观看 | 色网站免费在线观看 | av资源中文字幕 | 欧美激情视频一区二区三区免费 | 一区二区三区免费网站 | 久久激情视频 久久 | 成人黄色中文字幕 | 日韩视频一区二区三区 | 亚洲作爱 | 97精品国产97久久久久久免费 | 欧洲精品在线视频 | 日韩综合第一页 | 亚洲欧美国产精品久久久久 | 天天色婷婷 | 91在线免费观看网站 | 国产一区 在线播放 | 98超碰在线| 五月av在线 | 999成人免费视频 | 日日日日日 | 久久久久久久影视 | 一二三精品视频 | 中文字幕在线观看视频一区 | 久久黄网站 | 色婷婷福利 | 中文字幕亚洲欧美日韩 | 亚洲专区一二三 | 中文字幕精品一区 | 欧美日韩一区二区在线观看 | 97在线视| 超碰在线98 | 在线看免费 | 精品成人免费 | 99中文视频在线 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 久久久久亚洲精品国产 | 亚洲国产精品女人久久久 | 国产女人免费看a级丨片 | 成人黄色资源 | 欧美日韩久久 | 天天做日日爱夜夜爽 | 激情 婷婷 | 激情开心| 久久久久久久久久久久亚洲 | 国产 中文 日韩 欧美 | av看片在线| 国产91电影在线观看 | 五月开心综合 | 久久九九免费视频 | 激情视频网页 | 久久久久久久久久久久影院 | av福利在线| 亚洲一级片在线观看 | 高清不卡免费视频 | 国产免费看 | 国精产品999国精产品视频 | 成人av网址大全 | 日韩爱爱网站 | 九九免费观看视频 | 国产精品婷婷午夜在线观看 | 久久欧美在线电影 | 欧美极品在线播放 | 亚洲一区二区三区四区在线视频 | 国产一区二区在线免费播放 | 日韩免费一级电影 | 午夜久久久久久久 | 日韩av不卡播放 | 欧美精品一区二区在线播放 | 久久久久久伊人 | 人人超在线公开视频 | 91福利视频久久久久 | 久久久久久国产精品 | 欧美日韩中字 | 久久久久久蜜桃一区二区 | 国产精品美女久久久久久久久 | 99久久免费看 | 国产精品一区二区视频 | 免费看片亚洲 | 五月天九九 | 久久免费看a级毛毛片 | 免费开视频 | 国产精品都在这里 | 亚洲激情五月 | 91探花视频| 欧美精品做受xxx性少妇 | 福利视频导航网址 | 欧美日韩国产一区二区在线观看 | 日韩女同一区二区三区在线观看 | 91桃色在线播放 | 超碰在线观看99 | 国产精品私拍 | 国产一区av在线 | 色婷婷免费 | www国产一区 | 中文av影院| 亚洲综合网站在线观看 | 日韩成人av在线 | 免费在线黄| 亚洲日本va午夜在线影院 | 又大又硬又黄又爽视频在线观看 | 国产精品视频大全 | 免费看片黄色 | 国产日韩精品久久 | 国产精品一区二区在线免费观看 | 欧美成人精品三级在线观看播放 | 国产在线播放一区二区 | 日韩久久精品一区二区三区下载 | 91精品国产欧美一区二区 | 一级一片免费观看 | 最新日韩电影 | 亚洲成人免费观看 | 99国内精品久久久久久久 | 国际精品久久久 | 久久成人18免费网站 | 日韩免费精品 | 亚洲国产视频在线 | 91资源在线播放 | 五月天婷婷在线视频 | 国产免费观看视频 | 久久久久久伊人 | 成人av电影网址 | a在线观看视频 | 色噜噜狠狠狠狠色综合 | 日日干夜夜草 | 五月婷婷一区二区三区 | 欧美一级久久 | 国产福利一区二区三区在线观看 | 久久五月天综合 | 97**国产露脸精品国产 | 欧美日韩在线视频一区 | 久久久久久久久久久免费 | 国内精品久久久久久久久 | 激情丁香月 | 色婷婷免费视频 | 欧美激情视频在线观看免费 | 日韩免费福利 | 99人久久精品视频最新地址 | 成人动图 | 欧美极品久久 | 免费99视频| 日本少妇视频 | 在线免费视频一区 | 免费观看成年人视频 | 国产亚洲成人网 | 91男人影院 | 久久图| 麻花豆传媒mv在线观看网站 | 成全在线视频免费观看 | 黄色一区二区在线观看 | 婷婷六月天丁香 | 精品视频免费观看 | 色综合天天狠狠 | 99热播精品 | 亚洲日本va中文字幕 | 麻豆高清免费国产一区 | 国产在线观看一 | 国产精品国产精品 | 狠狠干天天 | 97av色| 国产婷婷精品av在线 | 97精品久久人人爽人人爽 | 狠狠色狠狠色综合日日小说 | 日韩高清在线一区二区三区 | 久久久在线 | 久久精品一区二区三区国产主播 | www久久久久 | 精品一二三四在线 | 精品欧美一区二区精品久久 | 美女久久久久久 | 久久精国产 | 伊人手机在线 | 一区二区三区高清不卡 | 色就是色综合 | 久久久999精品视频 国产美女免费观看 | www.狠狠插.com | 婷婷色五 | 51久久成人国产精品麻豆 | 在线免费试看 | 成人观看视频 | av中文字幕免费在线观看 | 亚洲精品av中文字幕在线在线 | 久久综合亚洲鲁鲁五月久久 | 99热亚洲精品 | 国产精品成人一区二区三区吃奶 | 国产96视频| 波多野结衣视频一区二区三区 | 亚洲成成品网站 | 免费在线观看国产黄 | 人人超碰97 | 国产精品一区二区av日韩在线 | 国产另类av | 日韩理论电影在线观看 | 99在线观看视频 | 国产99久久九九精品免费 | 久久er99热精品一区二区三区 | 日韩中文字幕视频在线 | 草久久久 | 精品主播网红福利资源观看 | 丁香花在线观看免费完整版视频 | 精品国产乱码久久久久久天美 | 激情综合色图 | 精品久久久成人 | 亚洲成人精品在线 | 免费人成在线观看 | 黄色电影网站在线观看 | 欧美国产日韩一区二区 | 99久久99精品 | 亚洲天堂在线观看完整版 | 国产一区二区在线免费 | 中国一区二区视频 | 亚洲第一色 | 日韩欧美aaa| 黄在线 | 日韩一区二区免费在线观看 | 蜜桃视频成人在线观看 | 伊人小视频 | 四虎国产永久在线精品 | 日韩欧美视频在线播放 | av网址aaa| 99视| 黄色网址中文字幕 | 国产丝袜在线 | 久久人人爽人人人人片 | 免费99精品国产自在在线 | 亚洲韩国一区二区三区 | 色网站视频 | 中文在线免费观看 | 五月天天色 | 一区二区三区av在线 | 亚洲成人黄色网址 | 51久久成人国产精品麻豆 | 91九色视频观看 | 国产电影黄色av | 婷婷伊人综合 | 日日色综合| 国产精品24小时在线观看 | 91人人视频在线观看 | 69久久久久久久 | 久久一级片 | 欧美一二三区播放 | www.av小说| 日韩精品一区二区三区视频播放 | 国产一区二区在线免费 | av网址aaa | 超碰免费久久 | 国产日韩中文字幕 | 欧美午夜视频在线 | 精品一区二区三区久久久 | 久久精品久久精品久久39 | 91av欧美| 国产精品网在线观看 | 91av视频在线观看 | 91视频久久久久久 | 中文字幕电影在线 | 欧美日韩精品影院 | 亚洲高清在线 | 欧美一级片在线观看视频 | 91传媒91久久久 | 四虎在线视频免费观看 | 久久精品日本啪啪涩涩 | 久草在线99 | 国产精品av在线免费观看 | 五月综合色 | 国产视频亚洲视频 | 日韩高清观看 | 久久精品视频免费 | 天堂av免费 | 国产 一区二区三区 在线 | 在线观看91网站 | 日韩大片免费在线观看 | 99免费看片 | 欧美日韩久久久 | 国产亚州精品视频 | 一区免费观看 | 午夜少妇 | 69精品久久| 97视频在线观看免费 | 麻豆传媒视频在线播放 | 成人黄色电影在线观看 | 日韩免费在线观看网站 | 久久精品精品 | 一区 二区电影免费在线观看 | 亚洲黄色小说网址 | 国产精品视频免费在线观看 | 国产黄色片免费在线观看 | 中文字幕一区二区在线观看 | 久久av在线播放 | 欧美日韩中文在线视频 | 1000部18岁以下禁看视频 | 亚洲最大av在线播放 | 黄色av电影在线观看 | 日韩精品一区二区在线视频 | 97人人网 | 欧美精品国产精品 | 字幕网资源站中文字幕 | 99视频免费在线观看 | 亚洲一区日韩精品 | 天天操天天色天天 | 国内精品久久久久久中文字幕 | 美女视频久久久 | 国产视频中文字幕在线观看 | 在线 视频 一区二区 | 日本mv大片欧洲mv大片 | 在线免费日韩 | 色在线高清 | 亚洲a色| 激情五月看片 | 国产小视频国产精品 | 深夜男人影院 | 亚洲爱爱视频 | 天天插一插 | 激情五月在线 | 狠狠精品 | 香蕉一区| 日韩中文字幕国产精品 | 九月婷婷人人澡人人添人人爽 | 国产一级精品在线观看 | 国产精品 中文字幕 亚洲 欧美 | www.天天操.com | 在线成人免费电影 | 99久久婷婷国产综合亚洲 | 国产最新在线 | 精品国产一二区 | 999国内精品永久免费视频 | www国产精品com | 国产精品久久久区三区天天噜 | 国产又粗又猛又爽又黄的视频先 | 欧美色操| 在线观看电影av | 一级黄色大片在线观看 | 久久伦理影院 | 成人av一二三区 | 久久久久久久精 | 午夜少妇一区二区三区 | 怡红院av久久久久久久 | 色婷婷av在线 | 91精品视频在线 | 香蕉视频国产在线 | 视频91| 在线综合 亚洲 欧美在线视频 | 制服丝袜欧美 | 91精品综合| 亚洲mv大片欧洲mv大片免费 | 在线看中文字幕 | 懂色av懂色av粉嫩av分享吧 | 日韩在线影视 | 精品一区中文字幕 | 国产精品免费大片视频 | 在线观看视频你懂得 | 2023亚洲精品国偷拍自产在线 | 午夜精品影院 | 黄色中文字幕在线 | 97av视频| 婷婷久久网站 | 四虎精品成人免费网站 | 天堂av高清 | 欧美国产高清 | 高清av中文字幕 | 日韩色在线 | 2024国产精品视频 | 操操日日 | 911国产在线观看 | 国产亲近乱来精品 | 欧美久久成人 | 午夜精品一区二区三区可下载 | 欧美日韩高清一区 | 亚洲精区二区三区四区麻豆 | 天天干视频在线 | 国产日产精品一区二区三区四区的观看方式 | 免费看片在线观看 | 又黄又爽的视频在线观看网站 | 免费精品视频在线 | 国产美女在线观看 | 麻豆视频免费观看 | 色吊丝av中文字幕 | 福利av影院 | 亚洲免费永久精品国产 | 天天做综合网 | 国产一级二级三级视频 | 中文字幕网址 | 人人爱夜夜操 | 人人草网站 | 伊人久久精品久久亚洲一区 | 久久艹在线| 久久午夜电影院 | 亚洲国产三级在线观看 | 国产精品久久久久久久久久久不卡 | 久久久久久免费 | 久久 地址 | 中文字幕国产精品 | 天天做综合网 | 久久99精品一区二区三区三区 | 精品国产乱码久久久久久浪潮 | 超碰在线中文字幕 | 国产v视频 | 国产精品免费久久久久影院仙踪林 | 麻豆国产在线视频 | 国产福利一区二区三区视频 | 国产一级片一区二区三区 | 中文字幕观看av | 夜夜躁狠狠躁 | 在线免费精品视频 | 成年人视频免费在线播放 | 国产999精品久久久久久绿帽 | 91精品国产成人 | 久久se视频 | 丁香五月亚洲综合在线 | 黄色三级免费网址 | 1000部18岁以下禁看视频 | 久久综合免费 | 天天色天天 | 在线观看爱爱视频 | 91av手机在线观看 | 日韩在线免费小视频 | 国产一区在线观看视频 | 黄色免费观看视频 | 国产免费a | 国产成人av福利 | 成人国产精品免费 | 亚洲电影久久久 | 69国产成人综合久久精品欧美 | 国产69精品久久99不卡的观看体验 | 亚洲综合在线播放 | 欧美精品久久久久久 | 福利区在线观看 | 欧美日韩二区在线 | 欧美一区日韩精品 | 中文字幕免费观看视频 | 人人添人人澡人人澡人人人爽 | 亚洲经典中文字幕 | 99久久久久久久 | 天天插天天 | 久久你懂的 | 日韩精品中文字幕久久臀 | a电影在线观看 | 国产精品一区二区美女视频免费看 | 黄色av一区二区三区 | 四虎影视国产精品免费久久 | 99re国产视频 | 人人插人人搞 | 久久久免费精品国产一区二区 | 天天摸日日操 | 中文字幕高清有码 | 国产精品美女久久久网av | 蜜臀aⅴ国产精品久久久国产 | 亚洲视频1 | 国产精品久久久久永久免费 | 九色精品免费永久在线 | 国产精美视频 | 欧美视频在线观看免费网址 | 一区免费视频 | 免费高清在线一区 | 婷婷在线播放 | 在线观看一区 | 精品国产伦一区二区三区观看说明 | 麻豆一二三精选视频 | 婷婷中文字幕 | 日本黄色片一区二区 | 国产亚洲高清视频 | 97人人添人澡人人爽超碰动图 | 国产精品24小时在线观看 | 久久精品久久久精品美女 | 欧美日韩不卡在线视频 | 国产美女搞久久 | 国产精品18videosex性欧美 | 人人干人人做 | 色噜噜在线观看视频 | 天天碰天天操 | 中文字幕一区二区三区乱码不卡 | 欧美精品在线观看 | 欧美孕妇视频 | 日日日操 | 色偷偷88888欧美精品久久 | 91少妇精拍在线播放 | 欧美一级在线 | 欧美粗又大 | 成年人视频免费在线播放 | 欧美成人性战久久 | 成人啊 v | 丁香资源影视免费观看 | 久久99精品国产麻豆婷婷 | 狠狠综合久久av | 9999亚洲| 成人影视片| 五月婷婷中文网 | 免费日韩一区二区三区 | 最近免费在线观看 | 69av网| .国产精品成人自产拍在线观看6 | 欧美一级性生活片 | 午夜视频在线观看一区二区三区 | 天无日天天操天天干 | 午夜精品久久久久久久99 | 国产在线观看免费观看 | 在线观看色网 | 国产精品成久久久久 | 国产精品久久一区二区三区不卡 | 成年人免费av网站 | 中文字幕av在线免费 | 丰满少妇在线观看资源站 | 在线播放av网址 | 97国产精品| 成人黄色在线视频 | 日日碰夜夜爽 | 国产免费又粗又猛又爽 | 精品久久电影 | av超碰免费在线 | 久久tv | 日韩区欠美精品av视频 | 久草在线最新免费 | 久久久久久久久网站 | 中文字幕在线观看第一区 | 国产大陆亚洲精品国产 | 西西444www大胆高清图片 | 中文字幕日韩一区二区三区不卡 | 中文字幕一区二区三区四区 | 中文字幕在线观看免费高清完整版 | 国产一级不卡毛片 | 高清av影院| 国产99久久久国产精品免费二区 | 久久久99国产精品免费 | 99热在线网站 | 激情xxxx | 国产亚洲在 | 国色天香永久免费 | 三级av在线播放 | 97夜夜澡人人双人人人喊 | 2022国产精品视频 | 久久国产精品系列 | 在线免费91 | 久久桃花网 | 97精品国产97久久久久久春色 | 日本久久高清视频 | 视频 国产区 | 日韩电影中文字幕 | 天天干天天操天天爱 | 国产精品欧美精品 | 欧美精品乱码久久久久久按摩 | 色网站中文字幕 | 日日夜夜干 | 狠狠色丁香九九婷婷综合五月 | 波多野结依在线观看 | 久久福利国产 | 精品久久久久久久久久久久 | 国产精品欧美久久久久久 | 国产精品美女999 | 国产日产高清dvd碟片 | 午夜在线免费观看 | 色香蕉网 | 色综合久久天天 | 国产中文字幕网 | 欧美精品三级在线观看 | 久久久久久久久久伊人 | 黄色三级免费片 | 2019av在线视频 | 天天拍天天爽 | 伊人狠狠色 | 免费看久久| av高清一区二区三区 | 黄色av免费在线 | av再线观看| 国产色综合| 97成人资源站 | 夜夜骑首页 | 97在线视频网站 | 成人av免费在线播放 | 91视频免费看片 | 91亚洲夫妻 | 色综合夜色一区 | 久草在线播放视频 | 国产精品福利无圣光在线一区 | 免费在线观看成人 | 97国产大学生情侣白嫩酒店 | 五月综合网站 | 国产一区二区中文字幕 | 成人小视频免费在线观看 | 色婷婷久久久综合中文字幕 | 99久久久成人国产精品 | 色av色av色av | 亚洲免费小视频 | 黄色小说视频在线 | 天天曰夜夜爽 | 国产精品久久久久久久久大全 | 亚洲最大成人网4388xx | www.色午夜.com| 激情视频91 | 国产成人一区二区三区在线观看 | 国产精品一区二区麻豆 | 91av蜜桃| 日日碰狠狠躁久久躁综合网 | 免费色视频 | 国产成人在线网站 | 日韩欧美在线观看一区二区 | 日韩高清在线不卡 | 91av在线国产 | 久热爱 | 在线观看蜜桃视频 | 深夜福利视频在线观看 | 蜜臀av夜夜澡人人爽人人 | 伊人宗合| 日韩高清在线一区二区 | 国产人成一区二区三区影院 | 九九亚洲视频 | 这里只有精品视频在线 | 午夜电影久久久 | 日韩一区二区三区视频在线 | 久久精品国产免费看久久精品 | 成人免费网站视频 | 亚洲精品永久免费视频 | 一级片免费观看视频 | 欧美午夜性生活 | 成人免费中文字幕 | 久久综合免费 | 亚洲免费一级 | 超碰在线最新网址 | 久久人人97超碰精品888 | 91精品999 | 日本中文字幕在线一区 | 亚洲第一av在线播放 | 性色av免费看 | 国产精品久久人 | 999热线在线观看 | 在线免费看片 | 91精品国产麻豆国产自产影视 | 国产一级片免费视频 | 国产高清在线免费观看 | 精品亚洲欧美一区 | 天天射天天色天天干 | 国产精品美女久久久久久网站 | 久久久国产精品视频 | 色综合激情久久 | 国产精品午夜av | 中文字幕在线观看免费观看 | 99re8这里有精品热视频免费 | 久久精品这里都是精品 | 这里只有精品视频在线 | 日韩毛片在线一区二区毛片 | 日韩久久一区二区 | 在线观看中文字幕网站 | 日日躁你夜夜躁你av蜜 | 中文字幕在线看片 | 亚洲国产人午在线一二区 | 国产又粗又猛又色 | 91在线影院| 66av99精品福利视频在线 | 国产伦理久久精品久久久久_ | 亚洲欧美日韩不卡 | 99精品欧美一区二区三区 | 成年人app网址| 狠狠色丁香久久婷婷综合丁香 | 国产97在线观看 | 精品视频久久 | 久久久久久美女 | 久久99九九99精品 | 婷婷丁香狠狠爱 | 人人艹视频 | 波多野结衣资源 | 日韩午夜精品福利 | 色欧美成人精品a∨在线观看 | 美女免费视频一区二区 | av日韩在线网站 | 国产手机免费视频 | 国产亚洲在线 | 香蕉在线观看视频 | 欧美一区中文字幕 | 人人超碰免费 | 最新av观看 | 欧美了一区在线观看 | 91国内在线 | 久久99亚洲精品 | 久久精品国亚洲 | 在线小视频国产 | 久久精品99国产国产 | 99精品热 | 日日夜夜操操操操 | 免费高清男女打扑克视频 | 欧美日韩国产一区二区三区 | 中文字幕一区二区三区久久 | 免费网址你懂的 | 在线观看岛国片 | 亚洲特级片| 久久精品牌麻豆国产大山 | 色综合天天爱 | 国产黄色av网站 | 精品国偷自产国产一区 | 91人人爽人人爽人人精88v | 中文字幕一二 | 中文字幕色在线视频 | 91免费视频国产 | 亚洲欧美日韩在线看 | 日本天天操 | 午夜一级免费电影 | 人人看人人做人人澡 | 久久黄色免费观看 | 国产 视频 高清 免费 | 久久怡红院 | 2022中文字幕在线观看 | 人人舔人人爱 | 国产精品视频app | 久久精品99久久久久久2456 | 粉嫩aⅴ一区二区三区 | 成人久久18免费网站图片 | 99综合影院在线 | 东方av在|