自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用ASP.NET中的GridView和ObjectDataSource

開發(fā) 后端
本文介紹了如何在asp.net 2.0中通過使用GridView和ObjectDataSource空間添加產(chǎn)品表格。

在主/從報(bào)表的最后一步是列出與選定的類別相關(guān)聯(lián)的產(chǎn)品. 要實(shí)現(xiàn)該功能,在頁面上增加一個(gè)GridView控件然后創(chuàng)建一個(gè)數(shù)據(jù)源控件(ObjectDataSource)并命名為productsDataSource.讓productsDataSource控件從ProductsBLL類的GetProductsByCategoryID(categoryID)獲取數(shù)據(jù).

選擇GetProductsByCategoryID(categoryID) 方法  

GridView和ObjectDataSource: 選擇GetProductsByCategoryID(categoryID) 方法

選擇該方法之后,數(shù)據(jù)源控件(ObjectDataSource)向?qū)崾疚覀兌x該方法的categoryID參數(shù)值. 要使用categories DorpDownList中選擇的值, 設(shè)置參數(shù)源為Control, 設(shè)置ControlID為Categories.

categoryID 參數(shù)設(shè)置為Categories DropDownList的值 

GridView和ObjectDataSource: categoryID 參數(shù)設(shè)置為Categories DropDownList的值

花一點(diǎn)時(shí)間在瀏覽器中檢查一下我們前面所做的工作. 第一次訪問頁面時(shí),那些屬于已選擇類別(Beverages)的產(chǎn)品已經(jīng)顯示出來了(如圖9), 但是當(dāng)改變DropDownList時(shí)并沒有更新產(chǎn)品數(shù)據(jù).這是由于必須引發(fā)一次回發(fā)(postback)GridView才會更新.有兩個(gè)方法可以實(shí)現(xiàn)(兩種方法都不需要寫任何代碼):

• 設(shè)置 categories 的AutoPostBack 屬性為 True. (你可以選中DropDownList’s smart tag 上的Enable AutoPostBack 選項(xiàng).) 這樣,只要用戶改變了DropDownList的選擇項(xiàng)都會引起一次回發(fā). 所以, 當(dāng)用戶在DropDownList中選擇了一個(gè)新的類別就會引起一次回發(fā),GridView 也會隨著新選擇的類別更新產(chǎn)品數(shù)據(jù). (在本教程中我們使用此方法.)

• DropDownList后面添加一個(gè)按鈕控件.  設(shè)置他的Text 屬性為”刷新”或類似的文本.使用這種方法, 用戶需要選擇一個(gè)新的類別然后單擊該按鈕.單擊按鈕將會引起一次回發(fā)并更新GridView顯示已選擇類別的產(chǎn)品.圖9和圖10演示了運(yùn)行后的主/從報(bào)表.

第一次訪問該頁面時(shí), 顯示Beverage 的產(chǎn)品  

GridView和ObjectDataSource: 第一次訪問該頁面時(shí), 顯示Beverage 的產(chǎn)品

選擇一個(gè)新的產(chǎn)品,自動引起一次回發(fā)并更新GridView  

GridView和ObjectDataSource: 選擇一個(gè)新的產(chǎn)品,自動引起一次回發(fā)并更新GridView 

增加”選擇類別”列表項(xiàng)

第一次訪問FilterByDropDownList.aspx 頁時(shí),類別DropDownList中第一個(gè)數(shù)據(jù)項(xiàng)(Beverages)默認(rèn)是選中的, GridView中顯示的也是beverage類別的產(chǎn)品. 比起顯示第一個(gè)類別的產(chǎn)品, 我們可以為DropDownList 添加一個(gè)默認(rèn)選擇項(xiàng),比如 “—選擇類別 --”,這樣也許更友好一些.要給DropDownList增加一個(gè)新的數(shù)據(jù)項(xiàng), 在屬性窗口中單擊Items 屬性的省略號圖標(biāo). 添加一個(gè)新的數(shù)據(jù)項(xiàng)并設(shè)置Text 為“—選擇類別--”設(shè)置Value 為-1.

增加 “—選擇類別--” 數(shù)據(jù)項(xiàng) 

GridView和ObjectDataSource:  增加 “—選擇類別--” 數(shù)據(jù)項(xiàng)

除了上面的方法,你還可以使用下面的標(biāo)記性語言(markup)為DorpDownList添加一個(gè)數(shù)據(jù)項(xiàng):

  1. < asp:DropDownList ID="categories" runat="server" AutoPostBack="True" DataSourceID="categoriesDataSource" 
  2.     DataTextField="CategoryName" DataValueField="CategoryID" EnableViewState="False">  
  3.     < asp:ListItem Value="-1">-- Choose a Category --< /asp:ListItem>  
  4. < /asp:DropDownList> 

另外,我們需要把DropDownList控件的AppendDataBoundItems屬性設(shè)置為True,因?yàn)閿?shù)據(jù)源控件中的類別數(shù)據(jù)綁定到DropDownList 時(shí), 將會覆蓋所有的手工增加的列表項(xiàng),除非你的AppendDataBoundItems屬性設(shè)置True.

設(shè)置AppendDataBoundItems 屬性為True 

GridView和ObjectDataSource: 設(shè)置AppendDataBoundItems 屬性為True

這樣,第一次訪問該頁面時(shí), ”—選擇類別—“數(shù)據(jù)項(xiàng)是被選中并且不顯示任何產(chǎn)品.

頁面第一次加載時(shí)不顯示產(chǎn)品 

GridView和ObjectDataSource: 頁面第一次加載時(shí)不顯示產(chǎn)品

沒有顯示產(chǎn)品的原因是由于”—選擇類別—“項(xiàng)被選中,該數(shù)據(jù)項(xiàng)的值是-1, 而數(shù)據(jù)庫中不存在CategoryID為-1的產(chǎn)品. 如果這正是你想要的那現(xiàn)在就可以打完收工了, 如果你希望在"--選擇類別--"項(xiàng)選中時(shí)顯示所有類別的產(chǎn)品,在ProductsBLL類中自定義GetProductsByCategoryID(categoryID)方法,如果categoryID參數(shù)值小于0則調(diào)用GetProducts()方法:

  1. public Northwind.ProductsDataTable GetProductsByCategoryID(int categoryID)  
  2. {  
  3.     if (categoryID <  0)  
  4.         return GetProducts();  
  5.     else 
  6.         return Adapter.GetProductsByCategoryID(categoryID);  

在這里使用的技巧與在后面的[聲明式語法]教程中顯示全部供應(yīng)商的相似,盡管在這個(gè)例子中我們使用了-1而不是使用null來指示是否應(yīng)該獲取全部記錄. 這是因?yàn)镚etProductsByCategoryID(categoryID)中的categoryID參數(shù)需要一個(gè)整型值,與之相反,在[聲明式語法]教程中我們傳入了一個(gè)字符串參數(shù).

圖14 顯示了當(dāng)”—選擇類別—“項(xiàng)選中時(shí)FilterByDropDownList.aspx頁面的截屏. 此時(shí),所有類型的產(chǎn)品默認(rèn)全部顯示, 用戶可以通過選擇特定的類別來縮小顯示范圍

默認(rèn)情況下顯示所有產(chǎn)品 

GridView和ObjectDataSource: 默認(rèn)情況下顯示所有產(chǎn)品

【編輯推薦】

  1. ASP.NET 2.0數(shù)據(jù)教程:給站點(diǎn)添加aspx頁面
  2. ASP.NET 2.0數(shù)據(jù)教程:創(chuàng)建母版頁
  3. ASP.NET跨頁面?zhèn)髦档募记?/A>
  4. ASP.NET 2.0數(shù)據(jù)教程:給DAL添加定制編碼
  5. ASP.NET 2.0數(shù)據(jù)教程:完成數(shù)據(jù)訪問層
責(zé)任編輯:book05 來源: 博客堂
相關(guān)推薦

2009-07-24 15:35:00

ASP.NET Gri

2009-07-27 08:51:24

ObjectDataS

2009-07-27 09:01:44

ObjectDataS

2009-07-20 18:02:48

GridView控件ASP.NET 2.0

2009-07-27 15:58:25

添加GridView

2009-07-24 16:15:00

擴(kuò)展ASP.NET G

2009-07-28 03:42:00

ASP.NET Gri

2009-07-27 16:09:05

GridView顯示數(shù)

2009-06-12 09:24:34

ASP.NET窗體ASP.NET MVC

2009-07-27 16:22:54

GridView選擇行

2009-08-14 13:20:29

ASP.NET Gri

2009-07-27 12:22:03

ASP.NET和ASPASP.NET入門教程

2009-07-29 16:08:07

ASP和ASP.NET

2009-08-04 17:20:37

PostBack和ViASP.NET

2009-07-24 10:10:22

ASP.NET

2009-07-24 16:17:42

WebRequestEASP.NET

2009-08-03 18:29:31

GridView與Da

2009-07-22 18:03:00

ASP.NET ASP

2009-07-20 15:39:32

ASP.NET緩存

2009-10-29 09:15:32

ASP.NET MVCDropDownLis
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號