天天看點

ASP.NET 2.0打造購物車和支付系統之一(1)

【導讀】在本系列文章中,我們基于ASP.NET 2.0建構了一個簡化的線上購物車和PayPal系統;并通過這個示例,對ASP.NET 2.0中新引入的GridView控件作了深入研究。 字串7

到目前為止,我幾乎在每一個我參加過的商業C#.net工程中使用了DataGrid控件;是以,當我第一次聽到有關于GridView是如何提高工作效率時,我飛快地試用了它。DataGrid和GridView都是ASP.NET 2.0中提供的新的控件類,它們允許你快速容易地顯示表格式資料;并且當線上觀看它們時,它們都能被轉換為用戶端HTML表格進行顯示。 字串7

一.簡介

這是系列文章的第一篇。在本篇中,我們将通過一個簡單的網上商店示例程式來集中讨論GridView控件的一些用法。注意,在每一篇文章中我們都使用相同的源檔案。為了觀察本文示例示範效果,你隻需要把下載下傳内容解壓到你的web伺服器上一個新的目錄并浏覽到該目錄名即可。例如,如果你把所有的内容解壓到一個你的web伺服器根目錄下的目錄“gridviewshop”,并導航到這個目錄:

http://www.yourserver.com/gridviewshop

如果一切順利,那麼你應該會看到一個如下圖1所示的站點:

ASP.NET 2.0打造購物車和支付系統之一(1)

圖1:本系列文章網上商店示範程式快照 字串6

二.GridView

如果你已經使用DataGrid實作了你的系統,包括你自己的定制分頁與排序方案,那麼,你真正不需要考慮更新到GridView;因為從終端效果來看,它們都生成相同的内容(都生成一個HTML表格)。然而,如果你剛開始開發一個新的系統,那麼,我建議你使用GridView,特别是如果你想利用它内置的分頁與排序功能的話。

通過在設計時刻設定各種屬性,你可以控制GridView從外觀到功能等若幹方面。在本系列文章後面,我們将會更為深入地探讨這些方面,通過把一些CSS類指派給表格行和表格列頭;當然,還要添加一些事件處理器以便允許使用者與每一行資料進行互動。

填充GridView類似于填充一個DataGrid。你隻需建立DataSource,然後使用如下代碼把它綁定到GridView即可:

myGridView.DataSource = yourDataSource;

myGridView.DataBind();

當然,借助于.NET 2.0,你還有另一種選擇,那就是建立一個SqlDataSource并把GridView直接綁定到其上。這是通過設定它的DataSourceID以比對你指派給SqlDataSource的ID實作的,即是:

字串5

作為個人,我并不太看重這種方法,盡管它是微軟推薦的建立你的GridView的方法。我比較喜歡更多地控制我的DataSource;因為,這樣以來我能夠手工過濾它的内容甚至更多,這也正是為什麼我在這個商店示範程式中沒有使用這個方法的原因。 

好,下面讓我們繼續讨論建構本文中的商店示範程式。其大緻情況是,在一個頁面上存在兩個GridViews;你在前面已經看到這個圖像。一個GridView用于顯示我們的商店的産品,而其它的内容對應于購物籃。

你能夠容易地把這兩部分拆分到它們各自的頁面中,但是為了簡化起見,我們把這些内容放到了一起。 字串2

如果你打開Default.aspx(它包括在本文相應的zip源碼檔案中),你能夠看到這個頁面是如何建立的。

大多數HTML僅僅用于實作包裝之目的;需要注意的是,位于頁面頂部的聲明以及主<form>标簽和位于其内的<GridView>标簽。 字串7

三.頁面聲明

<%@ page inherits="shop.site" src="cs/site.aspx.cs" %>

該頁面聲明簡單地告訴我們的頁面它屬于什麼命名空間和類。在這個例子中,我們的命名空間是“shop”而我們的類是“site”。還存在一個稱為“src”的額外屬性定義,它指向包含該站點類的普通的.cs文本檔案。 

繼續閱讀