DataGrid Web控件深度歷險(xiǎn)(3) part1
發(fā)表時(shí)間:2024-02-20 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]這篇文章是一系列關(guān)于使用DataGrid Web控件文章的第三篇。ASP.Net DataGrid Web控件可將數(shù)據(jù)庫(kù)信息顯示在HTML表格中,并且功能強(qiáng)大。在第一篇文章中我們討論了DataGrid的基本功能;在第二篇文章中我們討論了設(shè)定DataGrid顯示屬性的信息。本文將研究如何將事件與Da...
這篇文章是一系列關(guān)于使用DataGrid Web控件文章的第三篇。ASP.Net DataGrid Web控件可將數(shù)據(jù)庫(kù)信息顯示在HTML表格中,并且功能強(qiáng)大。在第一篇文章中我們討論了DataGrid的基本功能;在第二篇文章中我們討論了設(shè)定DataGrid顯示屬性的信息。本文將研究如何將事件與DataGrid聯(lián)系起來(lái)。
導(dǎo)言
在第一篇文章中我們研究了DataGrid的基本功能 (它是一個(gè)被設(shè)計(jì)用于在HTML表格標(biāo)簽中顯示數(shù)據(jù)的ASP.Net Web控件),展示了通過(guò)ASP.Net頁(yè)面顯示數(shù)據(jù)庫(kù)內(nèi)容是如何的簡(jiǎn)單。在第二篇文章中我們研究了如何自定義DataGrid的顯示。正如在先前演示(Demo)中看到的,通過(guò)很少的程序代碼我們就能以印象深刻的格式顯示數(shù)據(jù)庫(kù)信息。
雖然顯示數(shù)據(jù)非常有效,但是真正有用的是能否將某種形式的動(dòng)作與DataGrid聯(lián)系起來(lái)。例如,想象一下你正在為某個(gè)電子商務(wù)公司工作并被要求通過(guò)DataGrid顯示所有訂單信息。每一個(gè)訂單含有很多相關(guān)的數(shù)據(jù),包括訂購(gòu)的商品、訂購(gòu)時(shí)間、購(gòu)買者的信息(姓名、地址等)、購(gòu)買者選擇的運(yùn)貨方式等。在一個(gè)DataGrid中(為每一個(gè)訂單)顯示所有這些信息將會(huì)導(dǎo)致過(guò)度的信息顯示。
正如在DataGrid Web控件深度歷險(xiǎn)(2)中看到的,我們可以通過(guò)將AutoGenerateColumns屬性設(shè)為False,然后通過(guò)Columns屬性指定需要顯示的列。雖然這種做法使得數(shù)據(jù)易于理解,但是如果用戶同時(shí)希望能夠查看到任意一個(gè)訂單的復(fù)雜細(xì)節(jié),那又該怎么做呢?理想地我們希望在DataGrid的每一行上有一個(gè)標(biāo)記為Detail的按鈕,當(dāng)點(diǎn)擊這個(gè)按鈕后將顯示訂單的全部信息。
本文的示例將引領(lǐng)讀者創(chuàng)建一個(gè)非常類似的應(yīng)用。在前面的演示中我們顯示了ASPFAQs.com最受歡迎的10個(gè)常見(jiàn)問(wèn)題。本文將對(duì)該演示進(jìn)行擴(kuò)充以顯示10個(gè)常見(jiàn)問(wèn)題的最關(guān)鍵信息,同時(shí)每一行包含一個(gè)Detail按鈕。
構(gòu)建基礎(chǔ)
我們?cè)诘诙恼轮刑岬紻ataGrid控件允許在DataGrid的Columns標(biāo)記中放置一些BoundColumn標(biāo)記;叵胍幌旅恳粋(gè)BoundColumn標(biāo)記代表DataGrid中的一列。為了將按鈕放置在DataGrid中,我們可以使用ButtonColumn標(biāo)記,這與BoundColumn標(biāo)記的用法很類似。下面的代碼顯示如何將按鈕放置在DataGrid中:
<form runat="server">
<asp:DataGrid runat="server" id="dgPopularFAQs"
BackColor="#eeeeee" Width="85%"
HorizontalAlign="Center"
Font-Name="Verdana" CellPadding="4"
Font-Size="10pt" AutoGenerateColumns="False">
<HeaderStyle BackColor="Black" ForeColor="White" Font-Bold="True"
HorizontalAlign="Center" />
<AlternatingItemStyle BackColor="White" />
<Columns>
<asp:ButtonColumn Text="Details" HeaderText="FAQ Details" />
<asp:BoundColumn DataField="FAQID" Visible="False" />
<asp:BoundColumn DataField="Description" HeaderText="FAQ Description" />
</Columns>
</asp:datagrid>
</form>
示例運(yùn)行結(jié)果如下:
包含按鈕的DataGrid
本示例顯示一個(gè)包含Detail按鈕的DataGrid Web控件。按鈕以鏈接形式顯示;若想使鏈接成為標(biāo)準(zhǔn)的按鈕,需要在ButtonColumn標(biāo)記中輸入ButtonType=”PushButton”.
FAQ Details
FAQ ID
FAQ Description
Details
144
Where can I host my ASP Web site for free (similar to GeoCities or Tripod or any of the many other free Web site sites)?
Details
181
How can I format numbers and date/times using ASP.NET? For example, I want to format a number as a currency.
…
源代碼:
<% @Import Namespace="System.Data" %>
<% @Import Namespace="System.Data.SqlClient" %>
<script language="vb" runat="server">
Sub Page_Load(sender as Object, e as EventArgs)
BindData()
End Sub
Sub BindData()
'1. Create a connection
Dim myConnection as New SqlConnection(ConfigurationSettings.AppSettings("connectionString"))
'2. Create the command object, passing in the SQL string
Const strSQL as String = "sp_Popularity"
Dim myCommand as New SqlCommand(strSQL, myConnection)
'Set the datagrid's datasource to the datareader and databind
myConnection.Open()
dgPopularFAQs.DataSource = myCommand.ExecuteReader(CommandBehavior.CloseConnection)
dgPopularFAQs.DataBind()
End Sub
</script>
<form runat="server">
<asp:DataGrid runat="server" id="dgPopularFAQs"
BackColor="#eeeeee" Width="85%"
HorizontalAlign="Center"
Font-Name="Verdana" CellPadding="4"
Font-Size="10pt" AutoGenerateColumns="False">
<HeaderStyle BackColor="Black" ForeColor="White" Font-Bold="True" HorizontalAlign="Center" />
<AlternatingItemStyle BackColor="White" />
<Columns>
<asp:ButtonColumn Text="Details" HeaderText="FAQ Details" />
<asp:BoundColumn DataField="FAQID" HeaderText="FAQ ID" />
<asp:BoundColumn DataField="Description" HeaderText="FAQ Description" />
</Columns>
</asp:datagrid>
</form>
請(qǐng)注意為了使示例正常運(yùn)行,需要將DataGrid放置在一個(gè)服務(wù)器端的表單中(如上所示黑體的<form runat=”server”>)。這是因?yàn)闉榱烁櫛稽c(diǎn)擊的按鈕和應(yīng)該發(fā)生的關(guān)聯(lián)動(dòng)作,ASP.Net頁(yè)面應(yīng)能夠重新創(chuàng)建頁(yè)面和DataGrid中的一系列按鈕。為了做到這一點(diǎn)需要使用頁(yè)面的狀態(tài)信息(ViewState)。對(duì)狀態(tài)信息的討論超出了本文的范圍;為了獲取更多信息請(qǐng)閱讀: Form Viewstate。
注意在示例中創(chuàng)建的按鈕是一個(gè)文本鏈接按鈕。這是ButtonColumn類生成的缺省外觀。如果想顯示一個(gè)標(biāo)準(zhǔn)的按鈕,可在ButtonColumn標(biāo)記中指定ButtonType=”PushButton”。ButtonColumn類包含一些重要的屬性。在上面的代碼中使用了兩個(gè)格式方面的屬性。HeaderText屬性指定DataGrid中按鈕所在列的頁(yè)眉中的文字。Text屬性指定了每個(gè)按鈕的文本顯示。與BoundColumn標(biāo)記類似,ButtonColumn標(biāo)記可將每個(gè)按鈕的文本設(shè)為DataGrid的DataSource屬性中某一列的值-在ButtonColumn類中省略掉Text屬性并將DataTextField屬性設(shè)為數(shù)據(jù)庫(kù)中某個(gè)列的名稱,該列的值將作為按鈕的文本。