主頁(yè) > 知識(shí)庫(kù) > 在ASP.NET 2.0中操作數(shù)據(jù)之三十一:使用DataList來(lái)一行顯示多條記錄

在ASP.NET 2.0中操作數(shù)據(jù)之三十一:使用DataList來(lái)一行顯示多條記錄

熱門標(biāo)簽:臨沂智能電話機(jī)器人加盟 400電話辦理怎么樣 蘇州如何辦理400電話 地圖標(biāo)注軟件免費(fèi)下載 網(wǎng)絡(luò)電話外呼系統(tǒng)上海 聯(lián)通官網(wǎng)400電話辦理 西寧呼叫中心外呼系統(tǒng)線路商 外呼電話機(jī)器人成本 百應(yīng)電話機(jī)器人外呼系統(tǒng)

導(dǎo)言

  在前兩章的做的DataList的例子里我們都是使用單列的HTMLtable>來(lái)顯示數(shù)據(jù).而自定義使DataList將數(shù)據(jù)顯示在多列多行的table里也非常容易.而且還可以以單行多列來(lái)顯示數(shù)據(jù).

  我們可以通過(guò)RepeatColumns和RepeatDirection屬性來(lái)自定義DataList.這兩個(gè)屬性決定了數(shù)據(jù)顯示時(shí)候的列數(shù)和方向(水平或垂直).圖1是以一個(gè)3列的table來(lái)顯示product信息的DataList例子.

圖 1: DataList 一行顯示三條product信息

通過(guò)一行顯示多條記錄,DataList可以更有效的利用屏幕的水平空間.在這章里我們將探討這兩個(gè)屬性.

第一步: 在 DataList顯示Product信息

  在學(xué)習(xí)RepeatColumns和RepeatDirection屬性前,我們先用標(biāo)準(zhǔn)的單列多行DataList顯示Product信息.我們使用下面的標(biāo)記語(yǔ)言來(lái)顯示product的name,category和price:

h4>Product Name/h4>
Available in the Category Name store for Price

  在前面的教程里我們已經(jīng)做過(guò)如何將數(shù)據(jù)綁定到DataList,因此這一步我們很快帶過(guò).打開(kāi)DataListRepeaterBasics文件夾下的RepeatColumnAndDirection.aspx頁(yè),拖一個(gè)DataList進(jìn)去.從DataList的智能標(biāo)簽里創(chuàng)建一個(gè)ObjectDataSource,使用ProductsBLL類的GetProducts方法配置.在INSERT,UPDATE和DELETE標(biāo)簽里選擇None.

  在創(chuàng)建完ObjectDataSource并綁定到DataList后,Visual Studio會(huì)自動(dòng)創(chuàng)建一個(gè)顯示product字段的name和value的ItemTemplate.調(diào)整ItemTemplate— 通過(guò)直接修改標(biāo)記語(yǔ)言或智能標(biāo)簽里的Edit Templates選項(xiàng)— 將Product Name, Category Name和Price文本用Label控件來(lái)替代,用合適的綁定語(yǔ)法將分配的值綁定到Text屬性.在做完這些后,你的頁(yè)的標(biāo)記語(yǔ)言看起來(lái)應(yīng)該和下面差不多:

asp:DataList ID="DataList1" runat="server" DataKeyField="ProductID"
 DataSourceID="ObjectDataSource1" EnableViewState="False">
 ItemTemplate>
  h4>
   asp:Label runat="server" ID="ProductNameLabel"
    Text='%# Eval("ProductName") %>'>/asp:Label>
  /h4>
  Available in the
   asp:Label runat="server" ID="CategoryNameLabel"
    Text='%# Eval("CategoryName") %>' />
  store for
   asp:Label runat="server" ID="UnitPriceLabel"
    Text='%# Eval("UnitPrice", "{0:C}") %>' />
 /ItemTemplate>
/asp:DataList>
asp:ObjectDataSource ID="ObjectDataSource1" runat="server"
 OldValuesParameterFormatString="original_{0}"
 SelectMethod="GetProducts" TypeName="ProductsBLL">
/asp:ObjectDataSource>

  注意在UnitPrice的Eval綁定語(yǔ)法里我包含了一個(gè)格式符,用來(lái)將值轉(zhuǎn)換為貨幣格式- Eval("UnitPrice","{0:C}").在瀏覽器里瀏覽這個(gè)頁(yè),如圖2所示,DataList以單列多行的table顯示product信息.

圖 2: 默認(rèn)情況下DataList 顯示一個(gè)單列多行的table

第二步: 修改DataList的布局方向

  默認(rèn)情況下DataList垂直的用單列多行table來(lái)顯示項(xiàng)(item).這個(gè)可以通過(guò)RepeatDirection屬性來(lái)修改.將RepeatDirection屬性從Vertical改為Horizontal后,DataList會(huì)以單行多列顯示數(shù)據(jù).可以在設(shè)計(jì)器里選擇RepeatDirection屬性窗口修改這個(gè)屬性.修改完后設(shè)計(jì)器馬上會(huì)調(diào)整DataList的布局,創(chuàng)建一個(gè)單行多列的界面(見(jiàn)圖3).

圖 3: RepeatDirection屬性用來(lái)決定DataList的項(xiàng)的布局方向

  當(dāng)顯示小數(shù)據(jù)量時(shí),一個(gè)單行多列的table是一個(gè)理想的選擇.而大數(shù)據(jù)量時(shí),單行需要很多列,屏幕會(huì)因?yàn)轱@示不了這么多項(xiàng)而出現(xiàn)水平滾動(dòng)條.圖4顯示在單行的DataList里顯示product信息的情況.因?yàn)閜roduct的數(shù)量太多(81),用戶不得不向右滾動(dòng)來(lái)查看每個(gè)product的信息.

圖 4: 大數(shù)據(jù)量時(shí)單列的DataList會(huì)有水平滾動(dòng)條,

第三步: 以多列多行的table來(lái)顯示數(shù)據(jù)

  為了創(chuàng)建多行多列的DataList,我們需要設(shè)置RepeatColumns屬性為顯示的列數(shù).默認(rèn)的RepeatColumns屬性為0,因此DataList會(huì)單列或單行的顯示所有的項(xiàng)(取決于RepeatDirection屬性的值).

  我們將在例子里每行顯示3個(gè)product.因此設(shè)置RepeatColumns屬性為3.做完這個(gè)后,在瀏覽器里瀏覽頁(yè)面.如圖5所示,product顯示以3列多行列出.

圖 5: 每行顯示3條product

  RepeatDirection屬性影響DataList的項(xiàng)的布局.圖5顯示的是RepeatDirection為Horizontal的情況.注意最前面的三個(gè)product — Chai, Chang, and Aniseed Syrup — 是先從左到右,再?gòu)纳系较铝谐?后面的三個(gè)product(從Chef Anton's Cajun Seasoning開(kāi)始)在開(kāi)始三個(gè)下面的一行里.將RepeatDirection改為Vertical,這些product的布局變?yōu)橄葟纳系较?再?gòu)淖蟮接?見(jiàn)圖6.

圖 6: Products 垂直布局

  在最后的table里有多少行取決于記錄的總數(shù)除以RepeatColumns的值.由于有84條product信息,除以3為28行.如果還有余數(shù),最后的行或列會(huì)用空的cell填充.如果RepeatDirection為Vertical,那么最后的列會(huì)有空cell.如果RepeateDirection為Horizontal,那么最后的行有空cell.

總結(jié)

  DataList默認(rèn)情況使用單列多行的table來(lái)顯示項(xiàng).和GridView只有一個(gè)TemplateField差不多.我們可以一行顯示多條記錄來(lái).僅僅是設(shè)置RepeatColumns屬性為每行的列數(shù)就可以達(dá)到這個(gè)目的.另外,RepeatDirection屬性可以用來(lái)指定多行多列的table的內(nèi)容是水平布局 —先從左到右,再?gòu)纳系较?—或垂直的 —先從上到下,再?gòu)淖蟮接?

作者簡(jiǎn)介

  Scott Mitchell,著有六本ASP/ASP.NET方面的書(shū),是4GuysFromRolla.com的創(chuàng)始人,自1998年以來(lái)一直應(yīng)用 微軟Web技術(shù)。Scott是個(gè)獨(dú)立的技術(shù)咨詢顧問(wèn),培訓(xùn)師,作家,最近完成了將由Sams出版社出版的新作,24小時(shí)內(nèi)精通ASP.NET 2.0。他的聯(lián)系電郵為mitchell@4guysfromrolla.com,也可以通過(guò)他的博客http://ScottOnWriting.NET與他聯(lián)系。

您可能感興趣的文章:
  • ASP.NET 跨頁(yè)面?zhèn)髦捣椒?/li>
  • ASP.NET 2.0中的數(shù)據(jù)操作之九:跨頁(yè)面的主/從報(bào)表
  • 在ASP.NET 2.0中操作數(shù)據(jù)之二十六:排序自定義分頁(yè)數(shù)據(jù)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之二十七:創(chuàng)建自定義排序用戶界面
  • 在ASP.NET 2.0中操作數(shù)據(jù)之二十八:GridView里的Button
  • 在ASP.NET 2.0中操作數(shù)據(jù)之二十九:用DataList和Repeater來(lái)顯示數(shù)據(jù)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之三十:格式化DataList和Repeater的數(shù)據(jù)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之三十二:數(shù)據(jù)控件的嵌套
  • 在ASP.NET 2.0中操作數(shù)據(jù)之三十三:基于DataList和Repeater使用DropDownList過(guò)濾的主/從報(bào)表
  • 在ASP.NET 2.0中操作數(shù)據(jù)之三十四:基于DataList和Repeater跨頁(yè)面的主/從報(bào)表

標(biāo)簽:慶陽(yáng) 聊城 中衛(wèi) 清遠(yuǎn) 海西 甘肅 臨夏

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在ASP.NET 2.0中操作數(shù)據(jù)之三十一:使用DataList來(lái)一行顯示多條記錄》,本文關(guān)鍵詞  在,ASP.NET,2.0,中,操作,數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在ASP.NET 2.0中操作數(shù)據(jù)之三十一:使用DataList來(lái)一行顯示多條記錄》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于在ASP.NET 2.0中操作數(shù)據(jù)之三十一:使用DataList來(lái)一行顯示多條記錄的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章