上篇文章大概講了DataList的一些基礎知識,掌握這些知識在將來的應用中起到很大的作用,現在我們就開始講上篇文章中說的基礎知識做一個小例子。
首先,我機子的資料庫中有一張person表,如所示。
現在,我們用DataList控制項將表中的資訊顯示出來,並可以在DataList控制項上對資料庫中的表進行編輯操作。
1、首先用vs建立web應用程式,添加web表單,在web表單內拉入DataList控制項,右擊控制項,選擇編輯項目範本,在這裡我們能看到四個模板,其中兩個是SelectedItemTemplate和EditItemTemplate,在ItemTemplate模板中拉入兩個LinkButton控制項,一個將Text改名為查看,CommandName屬性改成select,另外一個將Text改成編輯,其CommandName屬性改成edit。然後在HTML頁面建立SelectedItemTemplate模板,在模板中綁定員工的所有資訊。(這裡是實現查看員工詳細資料的功能)。
2、在EditItemTemplate模板項中添加兩個LinkButton控制項,Text屬性分別為儲存和取消,CommandName屬性分別為update和cancel,然後再添加一個TextBox控制項,用來輸入姓名,在這裡實現修改員工姓名的功能。
3、我們還可以在屬性產生器總更改表格的樣式、將字型的顏色、網格的距離更改一下,這裡詳細不住不再敖述,最後結束模板編輯。
4、編輯前台HTML代碼
ItemTemplate模板中的代碼(用來顯示員工的姓名)
<ItemTemplate> <asp:LinkButton ID="lbtnShowDetails" runat="server" CommandName="select" ForeColor="Red">查看</asp:LinkButton> <asp:LinkButton ID="lbtnEdit" runat="server" CommandName="edit" ForeColor="Red">編輯</asp:LinkButton> <%# DataBinder.Eval(Container.DataItem,"personName") %> </ItemTemplate>
SelectedItemTemplate模板中的代碼(用來顯示員工中的詳細資料)
<SelectedItemTemplate> 員工編號: <%# DataBinder.Eval(Container.DataItem,"pID") %> <br /> 員工姓名: <%# DataBinder.Eval(Container.DataItem,"personName") %> <br /> 員工性別: <%# DataBinder.Eval(Container.DataItem,"personSex") %> </SelectedItemTemplate>
EditItemTemplate模板中的代碼(用來修改員工姓名)注意:將文字框中的text屬性綁定到員工的姓名上。
<EditItemTemplate> <asp:LinkButton ID="lbtnupdate" runat="server" CommandName="update">儲存</asp:LinkButton> <asp:LinkButton ID="lbtnCancel" runat="server" CommandName="cancel">取消</asp:LinkButton> <br /> 員工編號:<%# DataBinder.Eval(Container.DataItem,"pID") %> <br />姓名:<asp:TextBox ID="txtName" runat="server" <span style="color:#FF0000;">Text='<%# DataBinder.Eval(Container.DataItem,"personName") %>'</span> Width="50px"> </asp:TextBox> </EditItemTemplate>
最後是頁首和頁尾模板
<HeaderTemplate> 模板的頁首 </HeaderTemplate> <FooterTemplate> <br /> 模板的頁尾 </FooterTemplate>
5、編輯好了的前台介面如下
6、後台代碼的編寫
6.1、 編寫DataList資料繫結的方法
private void dataBindToDataList() { SqlConnection con = DB.createConnection(); SqlDataAdapter sda = new SqlDataAdapter(); string sql = "select * from person "; sda.SelectCommand = new SqlCommand(sql, con); DataSet ds = new DataSet(); sda.Fill(ds, "per"); DataList1.DataKeyField = "pID"; //將主鍵存入到DataKeys集合當中,以便後面對某一條資料進行編輯。 DataList1.DataSource = ds.Tables["per"]; DataList1.DataBind(); }
6.2、編寫Page_Loda事件,判斷頁面是否第一次載入,並在第一次載入頁面時綁定資料。
protected void Page_Load(object sender, EventArgs e) { if (!this.IsPostBack) { this.dataBindToDataList(); } }
6.3、編寫DataList1_ItemCommand事件,實現查看員工詳細資料功能(前提是我們已經在SelectedItemTemplate模板中將員工的詳細資料已經綁定,現在只是調用方法將其顯示出來)
protected void DataList1_ItemCommand(object source, DataListCommandEventArgs e)// e表示DataList傳遞給該函數的資訊。 { if (e.CommandName == "select") { this.DataList1.SelectedIndex = e.Item.ItemIndex; this.dataBindToDataList(); } }
6.4、編寫DataList1_EditCommand事件,實現編輯功能,將EditItemTemplate模板中的資訊顯示出來。
protected void DataList1_EditCommand(object source, DataListCommandEventArgs e)// e表示DataList傳遞給該函數的資訊。 { this.DataList1.EditItemIndex = e.Item.ItemIndex;//e.Item表示DataList中發生事件的那一項 this.dataBindToDataList(); }
這時候,編輯模板項的綁定資訊就會顯示出來,我們可以在這更改姓名,或者取消編輯,如下
最後是取消修改功能的代碼、更新功能的代碼、刪除功能的代碼,事件分別為DataList1_CancelCommand、DataList1_UpdateCommand、DataList1_DeleteCommand。
protected void DataList1_CancelCommand(object source, DataListCommandEventArgs e)// e表示DataList傳遞給該函數的資訊。 { DataList1.EditItemIndex = -1; //當EditItemIndex屬性值為-1時,表示不顯示EditItemTemplate模板 dataBindToDataList(); } protected void DataList1_UpdateCommand(object source, DataListCommandEventArgs e) { string ID =DataList1.DataKeys[e.Item.ItemIndex].ToString(); string name = ((TextBox)e.Item.FindControl("txtName")).Text ; SqlConnection con = DB.createConnection(); SqlCommand cmd = new SqlCommand("update person set personName='"+name+"'where pID='"+ID+"'",con); cmd.ExecuteNonQuery(); DataList1.EditItemIndex = -1; dataBindToDataList(); } protected void DataList1_DeleteCommand(object source, DataListCommandEventArgs e) { string ID = DataList1.DataKeys[e.Item.ItemIndex].ToString(); SqlConnection con = DB.createConnection(); SqlCommand cmd = new SqlCommand("delete from person where pID='" + ID + "'", con); cmd.ExecuteNonQuery(); DataList1.EditItemIndex = -1; dataBindToDataList(); }
總結
用DataList控制項實現對資料庫中person表的操作,實現查看詳細資料,修改操作,大致流程是先修改DataList控制項的各個模板中繫結資料,然後等待具體的事件使該模板中的內容顯示出來,最後再對資料進行操作。當資料配接器DateAdapter對象將資料來源中的資料填充到DataSet中後,我麼可以用DataList.DataKeyField=“主鍵欄位名” 語句將主鍵添加到DataList的DataKeys集合中,當我們要修改資料的時候可以再從該集合中取出要編輯的資料項目的主鍵,語句為DataList1.DataKeys[e.Item.ItemIndex]。這樣我們就可以隨心所欲的修改DataList表中的資料項目了。