By: Scott Watermasysk

Published: 4/10/2002

翻譯: Drason

模版控件能讓用戶幾乎不用花費(fèi)任何時(shí)間就創(chuàng)建出復(fù)雜的用戶界面. Asp.net有很多控件都使用了模版技術(shù)(D " /> 日本一区二区高清,91资源在线观看,少妇精品久久久一区二区

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

動(dòng)態(tài)ItemTemplate的實(shí)現(xiàn)(譯) - item,template

原文: Implementing Dynamic ItemTemplates

By: Scott Watermasysk

Published: 4/10/2002

翻譯: Drason

模版控件能讓用戶幾乎不用花費(fèi)任何時(shí)間就創(chuàng)建出復(fù)雜的用戶界面. ASP.NET有很多控件都使用了模版技術(shù)(DataGrid就是一個(gè)例子). 而這些控件都工作得很好, 通常, 模版可以被保存為ascx文件以增加復(fù)用性. 很有可能, 事前你是不知道你的控件是怎么布局的, 而且你需要?jiǎng)討B(tài)的添加一些模版以應(yīng)付不同的事件.

使用模版的另一個(gè)優(yōu)勢(shì),就是它們能動(dòng)態(tài)的添加到你的控件里面去. 這樣的話, 你可以事先設(shè)計(jì)好模版, 然后通過簡單的幾行代碼就添加到你的控件中.

下面這篇文章就要告訴你如何如何一步步的添加一個(gè)動(dòng)態(tài)的ItemTemplate和EditItemTemplate到DataGrid中. 另外, 還會(huì)告訴你怎么獲取和更新用戶對(duì)EditItemTemplate所做的改變. 例子將會(huì)是很簡單的. 然后, 我很快就會(huì)在TripleASP上面正式發(fā)布一個(gè)改進(jìn)后的TableEditor版本. 這個(gè)版本將更好的說明如何使用動(dòng)態(tài)模版.

ITempalte的實(shí)現(xiàn) 
為了能動(dòng)態(tài)的添加ItemTemplate和EditItemTemplate, 我們需要?jiǎng)?chuàng)建2個(gè)類來實(shí)現(xiàn)ITemplate的接口(Interface). 第一個(gè)類是GenericItem. 這個(gè)類的主要工作就是: 取數(shù)據(jù)源的列名, 創(chuàng)建一個(gè)文本控件(literal contral), 為這個(gè)文本控件賦值, 最后把這個(gè)文本控件加到父控件(在這里父控件就是DataGrid了). 

到目前為止還是很順利. 在繼續(xù)下面的討論之前, 我們來看看代碼和完成的步驟.

using System;

using System.Web;

using System.Data; using System.Web.UI;

using System.Web.UI.WebControls;

namespace TripleASP.ItemTemplates

{

/// <summary>

/// Summary description for GenericItem.

/// </summary>

public class GenericItem : ITemplate

{

private string column;

//private bool validate;

public GenericItem(string column)

{

this.column = column;

}

public void InstantiateIn(Control container)

{

Literal l = new Literal();

l.DataBinding += new EventHandler(this.BindData);

container.Controls.Add(l);

}

public void BindData(object sender, EventArgs e)

{

Literal l = (Literal) sender;

DataGridItem container = (DataGridItem) l.NamingContainer;

l.Text = ((DataRowView) container.DataItem)[column].ToString();

}

}

}

正如你看到的, GenericItem類實(shí)現(xiàn)了ITemplate的接口(interface). 因?yàn)槲覀兪菍?shí)現(xiàn)接口, 所以必須包括InstantiateIn這個(gè)方法. 這個(gè)方法是用來定義所有子控件和模版所屬的控件對(duì)象的. 在這個(gè)方法里面, 我們創(chuàng)建了一個(gè)新的Literal控件來保存DataGrid的單元值. 接著, 我們添加了DataBinding事件處理函數(shù). 這個(gè)事件處理函數(shù)實(shí)際上就是在DataGrid綁定數(shù)據(jù)的時(shí)候, 把單元值放到Literal控件的Text屬性中. 最后, 把這個(gè)Literal控件加入到控件的容器集合中. 很簡單吧?

動(dòng)態(tài)EditItemTemplate 

動(dòng)態(tài)EditItemTemplate類ValidateEditItem跟GenericItem很類似, 但是有3個(gè)地方不同.

第一個(gè)不同的地方是, 我們添加的是Textbox控件而不是Literal控件. 這樣的話, 在編輯模式下, 用戶可以做任何修改.

第二個(gè)不同的地方, 你會(huì)發(fā)現(xiàn)我們會(huì)顯式地命名控件. 這會(huì)使我們能夠獲取更新事件中的任何數(shù)據(jù)變化.

最后一個(gè)不同, 你會(huì)看到一個(gè)跟Textbox相聯(lián)系的RequiredFieldValidator控件. 這是可選的. 但是, 這的確讓你知道有些事是可以這樣做的.

下面就是ValidateEditItem的代碼:

using System;

using System.Data;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web;

namespace TripleASP.ItemTemplates

{

/// <summary>

/// Summary description for ValidateEditItem.

/// </summary>

public class ValidateEditItem : ITemplate

{

private string column;

public ValidateEditItem(string column)

{

this.column = column;

}

public void InstantiateIn(Control container)

{

TextBox tb = new TextBox();

tb.DataBinding += new EventHandler(this.BindData);

container.Controls.Add(tb);

tb.ID = column;

RequiredFieldValidator rfv = new RequiredFieldValidator();

rfv.Text = "Please Answer";

rfv.ControlToValidate = tb.ID;

rfv.Display = ValidatorDisplay.Dynamic;

rfv.ID = "validate" + tb.ID;

container.Controls.Add(rfv); 

}

public void BindData(object sender, EventArgs e)

{

TextBox tb = (TextBox) sender;

DataGridItem container = (DataGridItem)tb.NamingContainer;

tb.Text = ((DataRowView) container.DataItem)[column].ToString();

}

}

}

動(dòng)態(tài)模版的實(shí)現(xiàn) 

現(xiàn)在我們已經(jīng)有兩個(gè)實(shí)現(xiàn)了ITempalte接口的類了. 一切準(zhǔn)備好了! 我們現(xiàn)在要做的就是把它們加入到我們的datagrid里面.

我們把BindData和DynamicColumns兩個(gè)方法放在一起. BindData主要是創(chuàng)建SQL查詢語句, 往datagrid添加列(動(dòng)態(tài)列), 然后把數(shù)據(jù)表綁定到datagrid.

void BindData()

{

string sql = "Select * from publishers Where State Is not null";

DataGrid1.Columns.Add(DynamicColumns("pub_id",false));

DataGrid1.Columns.Add(DynamicColumns("pub_name",true));

DataGrid1.Columns.Add(DynamicColumns("city",true));

DataGrid1.Columns.Add(DynamicColumns("state",true));

DataGrid1.Columns.Add(DynamicColumns("country",true));

DataGrid1.DataKeyField = "pub_id";

DataGrid1.DataSource = GetDataTable(sql);

DataGrid1.DataBind();

}

DynamicColumns有兩個(gè)參數(shù): column(字符類型)和isEditable(布爾類型). column變量當(dāng)然就是我們要加入TemplateColumn的列名. isEditable變量是用作測(cè)試的, 如果我們希望這個(gè)列是允許編輯的話.

protected TemplateColumn DynamicColumns(string column, bool isEditable)

{

TemplateColumn genericcolumn = new TemplateColumn();

genericcolumn.HeaderText = column;

genericcolumn.ItemTemplate = new GenericItem(column);

if(isEditable)

{

genericcolumn.EditItemTemplate = new ValidateEditItem(column);

}

return genericcolumn;

}

正如你所看到的, 首先我們實(shí)例化一個(gè)TemplateColumn(genericcolumn), 根據(jù)我們要添加的列的名字設(shè)置HeaderText屬性(當(dāng)然,你可以設(shè)置為任何東西都可以). 接著, 我們通過添加新的GenericItem的參考(reference), 把ItemTemplate添加到genericcolumn, 并把名稱傳入. 最后, 我們必須檢查isEditable, 以便看看我們需不需要允許編輯這個(gè)列. 如果為真, 我們要往ValidateEditItem添加新的參考, 而且把列名也傳過去.

DataGrid事件 

我們的編輯和取消事件是很標(biāo)準(zhǔn)的. 你有可能已經(jīng)看過它們100遍了. 在我們的編輯事件里面, 我們簡單地取出被選中的行的編號(hào), 然后重新綁定數(shù)據(jù).

protected void Edit_Click(Object sender, DataGridCommandEventArgs e)

{

DataGrid1.EditItemIndex = e.Item.ItemIndex;

BindData();

}

我們的取消事件是把當(dāng)前所選行號(hào)設(shè)為-1. 這樣就等于告訴datagrid, 不在是編輯模式了. 然后, 我們重新綁定數(shù)據(jù).

protected void Cancel_Click(Object sender, DataGridCommandEventArgs e)

{

DataGrid1.EditItemIndex = -1;

BindData();

}

更新事件會(huì)跟你以前看到的有一點(diǎn)點(diǎn)不同. 然而, 它卻會(huì)讓你想起你在ASP的日子.

protected void Update_Click(Object sender, DataGridCommandEventArgs e)

{

//Gets the UniqueID that is attached to the front of each textbox

//dyamically added to our datagrid's EditItemTempate

string uid = e.Item.UniqueID + ":";

string pub_id = (string)DataGrid1.DataKeys[e.Item.ItemIndex];

string pub_name = (Request.Form[uid + "pub_name"].ToString());

string city = (Request.Form[uid + "city"].ToString());

string state = (Request.Form[uid + "state"].ToString());

string country = (Request.Form[uid + "country"].ToString());

//Simple method to update DB

UpdateRecord(pub_id,pub_name,city,state,country);

DataGrid1.EditItemIndex = -1;

BindData();

}

這樣的話, EditItemTemplate就硬編碼到頁面中去了. 你可能已經(jīng)看過一些取表單提交數(shù)據(jù)的例子, 其中的方法, 或者是通過控件位置取值, 或者是控件名稱取值. 但是, 如果你是在運(yùn)行時(shí)創(chuàng)建控件, 那么, 在PostBack的時(shí)候, ASP.NET是無法取得這些值的. 為此, 我們只能通過Request.Form的方法來得到這些值.

在你開始在ValidateEditItem類里面仔細(xì)尋找被小心命名的textbox的時(shí)候, 你必須記住, ASP.NET已經(jīng)為控件的名字沖突做了預(yù)防措施. 一般來說, 這包括增加每個(gè)datagrid父控件的名稱, datagrid本身的名稱, 和一個(gè)代表每個(gè)textbox的序號(hào)的字符串放在textbox的ID前面. 我們可以大量的使用這樣的方法. 但是這并不保證我們的代碼絕對(duì)的模塊化和可復(fù)用. 相反, 我們檢查DataGridCommandEventArgs.Item.UniqueID 并在尾部加上":". 有了這個(gè)UniqueID, 我們就可以安全地取得textbox里面的編輯數(shù)據(jù), 并更新到數(shù)據(jù)庫.

結(jié)論 

動(dòng)態(tài)添加模版到你的模版控件會(huì)在開始的時(shí)候增加一點(diǎn)點(diǎn)的工作量. 但是, 一旦你建立了一系列的優(yōu)秀的模版類, 你會(huì)發(fā)現(xiàn), 實(shí)現(xiàn)ITemplate會(huì)非常的快速和容易. 它運(yùn)行你建立強(qiáng)大的控件來滿足你數(shù)據(jù)操作的需要. 如果你需要更好的例子, 請(qǐng)看我即將發(fā)布在TripleASP的TableEditor控件.

AspNet技術(shù)動(dòng)態(tài)ItemTemplate的實(shí)現(xiàn)(譯) - item,template,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 云南省| 东丽区| 将乐县| 博罗县| 新平| 错那县| 静安区| 壤塘县| 永德县| 科技| 衢州市| 庐江县| 宝清县| 吉林市| 香河县| 望谟县| 崇阳县| 新河县| 定襄县| 六枝特区| 朝阳市| 宣威市| 清涧县| 文成县| 桂阳县| 澜沧| 新平| 南投县| 高尔夫| 扎鲁特旗| 无锡市| 浪卡子县| 龙川县| 华安县| 津南区| 威远县| 临江市| 高雄县| 光山县| 尚义县| 岑溪市|