<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      ASP.NET2.0中Gridview中數據操作技巧[學習筆記]

      Asp.net 2.0中新增的gridview控件,是十分強大的數據展示控件,在前面的系列文章里,分別展示了其中很多的基本用法和技巧(詳見<<ASP.NET 2.0中Gridview控件高級技巧>>、<<ASP.NET2.0利用Gridview實現主從關系>>)。在本文中,將繼續探討有關的技巧。

        一、Gridview中的內容導出到Excel

        在日常工作中,經常要將gridview中的內容導出到excel報表中去,在asp.net 2.0中,同樣可以很方便地實現將整個gridview中的內容導出到excel報表中去,下面介紹其具體做法:

        首先,建立基本的頁面default.aspx

      <form id="form1" runat="server">
      <div>
      <asp:GridView ID="GridView1" runat="server">
      </asp:GridView>
      </div>
      <br/>
      <asp:Button ID="BtnExport" runat="server" OnClick="BtnExport_Click"
      Text="Export to Excel" />
      </form>

        在default.aspx.cs中,寫入如下代碼:

      protected void Page_Load(object sender, EventArgs e)
      {
       if (!Page.IsPostBack)
       {
        BindData();
       }
      }
      private void BindData()
      {
       string query = "Select * FROM customers";
       SqlConnection myConnection = new SqlConnection(ConnectionString);
       SqlDataAdapter ad = new SqlDataAdapter(query, myConnection);
       DataSet ds = new DataSet();
       ad.Fill(ds, "customers");
       GridView1.DataSource = ds;
       GridView1.DataBind();
      }

      public override void VerifyRenderingInServerForm(Control control)
      {
       // Confirms that an HtmlForm control is rendered for
      }

      protected void Button1_Click(object sender, EventArgs e)
      {
       Response.Clear();
       Response.AddHeader("content-disposition","attachment;filename=FileName.xls");
       Response.Charset = "gb2312";
       Response.ContentType = "application/vnd.xls";
       System.IO.StringWriter stringWrite = new System.IO.StringWriter();
       System.Web.UI.HtmlTextWriter htmlWrite =new HtmlTextWriter(stringWrite);

       GridView1.AllowPaging = false;
       BindData();
       GridView1.RenderControl(htmlWrite);

       Response.Write(stringWrite.ToString());
       Response.End();
       GridView1.AllowPaging = true;
       BindData();
      }
      protected void paging(object sender,GridViewPageEventArgs e)
      {
       GridView1.PageIndex = e.NewPageIndex;
       BindData();
      }

        在上面的代碼中,我們首先將gridview綁定到指定的數據源中,然后在button1的按鈕(用來做導出到EXCEL的)的事件中,寫入相關的代碼。這里使用Response.AddHeader("content-disposition","attachment;filename=exporttoexcel.xls");中的filename來指定將要導出的excel的文件名,這里是exporttoexcel.xls。要注意的是,由于gridview的內容可能是分頁顯示的,因此,這里在每次導出excel時,先將gridview的allowpaging屬性設置為false,然后通過頁面流的方式導出當前頁的gridview到excel中,最后再重新設置其allowpaging屬性。另外要注意的是,要寫一個空的VerifyRenderingInServerForm方法(必須寫),以確認在運行時為指定的ASP.NET 服務器控件呈現HtmlForm 控件。

        二、訪問gridview中的各類控件

        在gridview中,經常要訪問其中的各類控件,比如dropdownlist,radiobutton,checkbox等,下面歸納下在gridview中訪問各類控件的方法。

        首先看下如何在gridview中訪問dropdownlist控件。假設在一個gridviw中,展現的每條記錄中都需要供用戶用下拉選擇的方式選擇dropdownlist控件中的內容,則可以使用如下代碼,當用戶選擇好gridview中的dropdownlist控件的選項后,點擊按鈕,則系統打印出用戶到底選擇了哪些dropdownlist控件,并輸出它們的值。

      public DataSet PopulateDropDownList()
      {
       SqlConnection myConnection =new SqlConnection(ConfigurationManager.ConnectionStrings["MyDatabase"].ConnectionString);
       SqlDataAdapter ad = new SqlDataAdapter("Select * FROM tblPhone", myConnection);
       DataSet ds = new DataSet();
       ad.Fill(ds, "tblPhone");
       return ds;
      }

        上面的代碼首先將數據庫中tblphone表的數據以dataset的形式返回。然后在頁面的itemtemplate中,如下設計:

      <ItemTemplate>
      <asp:DropDownList ID="DropDownList1" runat="server" DataSource="<%# PopulateDropDownList() %>"
      DataTextField="Phone" DataValueField = "PhoneID">
      </asp:DropDownList>
      </ItemTemplate>

        這里注意dropdownlist控件的datasource屬性綁定了剛才返回的dataset(調用了populatedropdownlist()方法),并要注意設置好datatextfield和datavaluefield屬性。

        然后,在button的事件中,寫入以下代碼:

      protected void Button2_Click(object sender, EventArgs e)
      {
       StringBuilder str = new StringBuilder();
       foreach (GridViewRow gvr in GridView1.Rows)
       {
        string selectedText = ((DropDownList)gvr.FindControl("DropDownList1")).SelectedItem.Text;
        str.Append(selectedText);
       }
       Response.Write(str.ToString());
      }

        這里,我們用循環,來獲得每一行的dropdownlist控件的值,并且將值添加到字符串中最后輸出。

        接著,我們來看下如何訪問gridview控件中的checkbox控件。經常在gridview控件中,需要給用戶多項選擇的功能,這個時候就需要使用checkbox控件。首先我們建立一個模版列,其中有checkbox如下:

      <asp:GridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="True"
      AutoGenerateColumns="False" DataKeyNames="PersonID" DataSourceID="mySource" Width="366px" CellPadding="4" ForeColor="#333333" GridLines="None">
      <Columns>
      <asp:CommandField ShowSelectButton="True" />
      <asp:BoundField DataField="PersonID" HeaderText="PersonID" InsertVisible="False"
      ReadOnly="True" SortExpression="PersonID" />
      <asp:BoundField DataField="Name" HeaderText="Name" SortExpression="Name" />
      <asp:TemplateField HeaderText="Select">
      <ItemTemplate>
      <asp:CheckBox ID="chkSelect" runat="server" />
      </ItemTemplate>
      <HeaderTemplate>
      </HeaderTemplate>
      </asp:TemplateField>
      </Columns>
      </asp:GridView>

        為了示意性地講解如何得到用戶選擇的checkbox,可以增加一個按鈕,當用戶選擇gridview中的選項后,點該按鈕,則可以輸出用戶選了哪些選項,在按鈕的CLICK事件中寫入如下代碼:

      for (int i = 0; i < GridView1.Rows.Count; i++)
      {
       GridViewRow row = GridView1.Rows[i];
       bool isChecked = ((CheckBox) row.FindControl("chkSelect")).Checked;
       if (isChecked)
       {
        str.Append(GridView1.Rows[i].Cells[2].Text);
       }
      }
      Response.Write(str.ToString());

        接下來,我們添加一個全選的選擇框,當用戶選擇該框時,可以全部選擇gridview中的checkbox.首先我們在headtemplate中如下設計:

      <HeaderTemplate>
      <input id="chkAll" onclick="javascript:SelectAllCheckboxes(this);" runat="server" type="checkbox" />
      </HeaderTemplate>

        javascript部分的代碼如下所示:

      <script language=javascript>
      function SelectAllCheckboxes(spanChk){
       var oItem = spanChk.children;
       var theBox=(spanChk.type=="checkbox")?spanChk:spanChk.children.item[0];
       xState=theBox.checked;
       elm=theBox.form.elements;
       for(i=0;i<elm.length;i++)
       if(elm[i].type=="checkbox" && elm[i].id!=theBox.id)
       {
        if(elm[i].checked!=xState)
        elm[i].click();
       }
      }
      </script>


      三、gridview中刪除記錄的處理

        在gridview中,我們都希望能在刪除記錄時,能彈出提示框予以提示,在asp.net 1.1中,都可以很容易實現,那么在asp.net 2.0中要如何實現呢?下面舉例子說明,首先在HTML頁面中設計好如下代碼:

      <asp:GridView DataKeyNames="CategoryID" ID="GridView1" runat="server" AutoGenerateColumns="False" OnRowCommand="GridView1_RowCommand" OnRowDataBound="GridView1_RowDataBound" OnRowDeleted="GridView1_RowDeleted" OnRowDeleting="GridView1_RowDeleting">
      <Columns>
      <asp:BoundField DataField="CategoryID" HeaderText="CategoryID" />
      <asp:BoundField DataField="CategoryName" HeaderText="CategoryName" />
      <asp:TemplateField HeaderText="Select">
      <ItemTemplate>
      <asp:LinkButton ID="LinkButton1" CommandArgument='<%# Eval("CategoryID") %>' CommandName="Delete" runat="server">Delete</asp:LinkButton>
      </ItemTemplate>
      </asp:TemplateField>
      </Columns>
      </asp:GridView>

        在上面的代碼中,我們設置了一個鏈接linkbutton,其中指定了commandname為"Delete",commandargument為要刪除的記錄的ID編號,注意一旦commandname設置為delete這個名稱后,gridview中的GridView_RowCommand 和 GridView_Row_Deleting 事件都會被激發接者,我們處理其rowdatabound事件中:

      protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
      {
       if (e.Row.RowType == DataControlRowType.DataRow)
       {
        LinkButton l = (LinkButton)e.Row.FindControl("LinkButton1");
        l.Attributes.Add('onclick", "javascript:return " + "confirm("是否要刪除該記錄? " +
        DataBinder.Eval(e.Row.DataItem, "id") + "')");
       }
      }

        在這段代碼中,首先檢查是否是datarow,是的話則得到每個linkbutton,再為其添加客戶端代碼,基本和asp.net 1.1的做法差不多。

        之后,當用戶選擇了確認刪除后,我們有兩種方法對其進行繼續的后續刪除處理,因為我們將刪除按鈕設置為Delete,方法一是在row_command事件中寫入如下代碼:

      protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
      {
       if (e.CommandName == "Delete")
       {
        int id = Convert.ToInt32(e.CommandArgument);
        // 刪除記錄的專門過程
        DeleteRecordByID(id);
       }
      }

        另外一種方法是使用gridview的row_deletting事件,先在頁面HTML代碼中,添加<asp:GridView DataKeyNames="CategoryID" ID="GridView1" runat="server" AutoGenerateColumns="False" OnRowCommand="GridView1_RowCommand" OnRowDataBound="GridView1_RowDataBound" onRowDeleting="GridView1_RowDeleting">
      然后添加row_deleting事件:

      protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
      {
       int categoryID = (int) GridView1.DataKeys[e.RowIndex].Value;
       DeleteRecordByID(categoryID);
      }

        要注意的是,這個必須將datakeynames設置為要刪除記錄的編號,這里是categoryid.

        小結

        在本文中,繼續探討了gridview控件的一些用法,如導出到excel,在刪除記錄時的處理,以及如何訪問gridview中的控件等。

      posted @ 2007-03-15 12:02  chinaifne  閱讀(683)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 中文字幕人妻av12| av午夜福利一片免费看久久| 新建县| 亚洲综合国产一区二区三区| 亚洲欧美高清在线精品一区二区| 人妻中文字幕不卡精品| 国产精品污双胞胎在线观看| 在线播放免费人成毛片| 亚洲国产精品一区在线看| 性色av无码久久一区二区三区| 思思热在线视频精品| 欧美成人看片一区二区三区尤物| 亚洲午夜精品毛片成人播放| 亚洲国产精品日韩在线| 2020中文字字幕在线不卡| 蜜臀av一区二区国产精品| 亚洲粉嫩av一区二区黑人| av天堂午夜精品一区| 旬阳县| 国内精品无码一区二区三区| 色噜噜狠狠成人综合| 久久精品国产亚洲不av麻豆| 国产亚洲一在无在线观看| 国产第一页屁屁影院| 体态丰腴的微胖熟女的特征| 青青青爽在线视频观看| 欧美人成精品网站播放| 亚洲の无码国产の无码步美| 美女一级毛片无遮挡内谢| 国产成人免费午夜在线观看| 人妻少妇精品系列| 午夜福利偷拍国语对白| 国产亚洲AV电影院之毛片| 巨鹿县| 黄色国产精品一区二区三区 | 国产精品无码dvd在线观看| 91精品国产蜜臀在线观看| 国产中文字幕在线精品| 久久精品国产亚洲AV麻| 日韩一区二区黄色一级片| 国产乱码精品一品二品|