本文我將介紹在三層Web體系開發中的兩種數據綁定模式,然後在不超過你已經會用的控件知識的情況下,來介紹能夠極大減少這種數據綁定模式的替代品--XLib庫文件。具體的說,本文開始我們介紹在三層體系結構裏常規的數據綁定方法,然後介紹XLib是如何提高這種綁定效率的。
1、 數據綁定流程
在三層Web體系結構裏,通常有四步來完成數據綁定任務:
1)從數據庫里加載數據到業務邏輯對象
2)在Web窗體上放置Web控件並使用業務邏輯對象進行填充數據。
3)將Web控件的值拷貝到業務邏輯對象的屬性裏
4)保存業務邏輯對象的屬性值到數據庫。
以具體的Customer爲例,在三層應用程序裏最簡單的數據綁定模式的步驟如下:
1)從數據庫Customer表裏加載合適的顧客記錄
2)將顧客記錄綁定到Customer業務對象上
3)將Customer業務對象綁定到Web控件上
4)用戶在窗體裏輸入數據並單擊Submit進行提交數據
5)將Web控件的更新事件綁定到Customer對象上
6)把Customer上的信息保存到表裏
7)將表裏的信息保存到Customer上
有多種方式執行這個流程,我概括起來有三種:
1、顯示生成數據綁定方式--使用大家都熟悉的前臺方式
2、Microsoft的方式--使用類型化的DataSet和FormView
3、XLib方式--使用反射技術和其他的.NET特性來分析綁定--在運行時獲取對象
1.2 代碼--業務邏輯對象和Web 頁面
爲了具體說明這三種方式的使用方法,我將使用Customer類和EditCustomer頁面作爲演示。下面是一些代碼,它將說明具體在什麼地方進行數據綁定。
通常,Customer類看起來類似如下:
{
//list all properties
//CRUD methods
public void Load()
{
//Binding #1
//Copy database record values into properties
}
public void Save()
{
//Binding #4
//Copy properties values into database record
}
public void Delete() ;
//Other methods specific to customer
public string GetCustomerFullName()..
}
編輯顧客頁面的代碼類似如下:
//與Form窗體有關的一些顧客屬性
//提交和取消按鈕
編輯用戶信息的後臺代碼類似如下:
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack){
//Check if adding new customer or updating
if (_isUpdateMode)
LoadData();
}
}
protected void btnSubmit_Click(object sender, EventArgs e)
{
if (!Page.IsValid)
return;
SaveData();
//Go Back
}
private void LoadData()
{
Customer customer=new Customer();
customerID=_customerID;
customer.Load();
//Binding #2
//Copy customer properties into control values
}
private void SaveData()
{
Customer customer=new Customer();
If (_isUpdateMode)
{
customer.ID=_customerID;
customer.Load();
}
//Binding #3
//Copy control values into customer properties
customer.Save();
}
}
2 三種數據綁定方式
2.1 方法1:顯式聲明數據綁定方式
編輯顧客信息的方法之一是顯式的數據綁定方式,這意味這對於每一個數據綁定都需要執行前面說的四個步驟,例如對於Customer的Load方法,可能的代碼類似如下:
{
…
//Load customer record using data reader
_firstName=(string)dataReader["FirstName"];
_lastName=(string)dataReader["LastName"];
…
}
在這種情況下,當Customer對象有更多屬性時,您就需要編寫更多的代碼來完成數據綁定功能。如果您想爲Customer新增加一個屬性,你不得不在6個地方進行更改:
1)數據庫
2)數據綁定1--數據業務邏輯對象
3)數據綁定2--業務邏輯對象在綁定到Web控件上
4)在Web窗體上添加新的控件
5)數據綁定3--Web控件綁定到業務邏輯上
6)數據綁定4--業務邏輯到數據庫上
正如您所看到的上面方法的缺點--重複工作大且維護困難
2.2 使用微軟的方式--類型化的DataSet和FormView
對於這個方法,微軟已經爲我們提供了很多例子了,,如果您的程序足夠簡單,那麼您就可以從Customer表裏生成一個類型化的DataSet,並將其綁定到FormView上,由FormView來執行添加和編輯Customer對象的功能,您可以在下面兩個地方發現如何使用他們:
Modifying Data using FormView web control
對於 Database和Business對象之間的綁定,您可以使用類型化的DataSet嚮導完成,對於Busiess和Web控件之間的綁定您可以使用FormView控件的InserItemTemplate和EditItemTemplate 模板完成,並制定綁定規則,類似代碼如下:
您可能已經注意到了在微軟提供的例子裏使用這種方式對簡單應用程序來說,工作的確實相當的好,但是對於稍微複雜的應用程序來說,您就需要不斷擴展自己的代碼。
這種方式可以簡單數據的維護,例如你需要爲Customer增加一個新的屬性,你就只需要更改三處就可以了:
1、數據庫
2、Web Form - EditItemTemplate
3、Web Form - InsertItemTemplate
2.3 XLib方式的綁定
XLib在同時能夠提供前面介紹的兩種綁定方式外,還增加了數據維護方面的靈活性。XLib使用反射技術來自動從業務邏輯對象到數據庫,到Web控件之間的映射。
在執行數據庫到業務邏輯對象方面,它使用了XbusinessObjectBinder對象,下面的代碼片斷樣式了Customer對象的代碼:
{
…
public void Load()
{
dataReader=new XDataReader();
//Load data using auto-generated query into XDataReader
//XDataReader works just like data reader - except it automatically
//converts Database values types into INulllable C# types
//Binding #1
XBusinessObjectBinder.FromDataReader(this, dataReader);
}
public void Save()
{
XDataWriter dataWriter=new XDataWriter();
//XDataWriter automatically generates INSERT/UPDATE/DELETE sql s
//statements
//Binding #4
XBusinessObjectBinder.ToDataWriter(this, dataWriter)
dataWriter.Update();
}
}
對於業務邏輯到Web控件的綁定,它提供了XWebControlsBinder 控件,下面代碼片斷顯示了顧客編輯頁面的代碼:
{
protected void Page_Load(object sender, EventArgs e)
{…}
protected void btnSubmit_Click(object sender, EventArgs e)
{…}
private void LoadData()
{
Customer customer=new Customer();
customerID=_customerID;
customer.Load();
//Binding #2
XWebControlsBinder.FromObject(this, customer);
}
private void SaveData()
{
Customer customer=new Customer();
if (_isUpdateMode)
{
customer.ID=_customerID;
customer.Load();
}
//Binding #3
//Copy control values into customer properties
XwebControlsBinder.ToObject(this, customer);
customer.Save();
}
}
正如您所看到的,這種方法既去掉了第一種方法的缺點,又具有第二中方法的有點。