您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關ASP.NET中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 >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(); }
以上就是ASP.NET中DataList控件如何使用,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。