TreeView控件可以使用XML文檔作為數(shù)據(jù)源,根據(jù)XML文檔的層次結(jié)構(gòu)顯示節(jié)點(diǎn)。而XML文檔的訪問由XmlDataSource控件來完成,從XmlDataSource控件的DataFile屬性中指定XML文檔路徑,然后在TreeView控件中設(shè)置與XML文檔中的節(jié)點(diǎn)的對應(yīng)關(guān)系。本示例將演示如何把TreeView控件綁定到XML數(shù)據(jù)源。
技術(shù)要點(diǎn)
把TreeView控件綁定到XML數(shù)據(jù)源的技術(shù)要點(diǎn)如下。
使用XmlDataSource控件提供對XML文檔的訪問。
在TreeView控件的DataBindings屬性中指定節(jié)點(diǎn)與XML文檔的對應(yīng)關(guān)系。
實(shí)現(xiàn)步驟
(1)在VS2008中創(chuàng)建一個ASP.NET網(wǎng)站,命名為“TreeViewSample2”。
(2)添加一個頁面,命名為“TreeViewControl.aspx”,并把這個頁設(shè)置為起始頁。
(3)在“App_Data”文件夾中創(chuàng)建一個XML文檔,命名為“XMLFile.xml”,該文檔包含三層結(jié)構(gòu):聯(lián)系人、地區(qū)和負(fù)責(zé)人。代碼如下所示。
代碼如下:
<?xml version="1.0" encoding="utf-8" ?>
<contact name="聯(lián)系人">
<genre name="華南地區(qū)">
<person Text="負(fù)責(zé)人">
<name>
張三</name>
<sex>
男</sex>
<age>
25</age>
<address>
廣州市黃浦區(qū)</address>
</person>
<person Text="負(fù)責(zé)人">
<name>
李四</name>
<sex>
男</sex>
<age>
28</age>
<address>
佛山市南海區(qū)</address>
</person>
</genre>
<genre name="華北地區(qū)">
<person Text="負(fù)責(zé)人">
<name>
王五</name>
<sex>
男</sex>
<age>
30</age>
<address>
北京市海淀區(qū)</address>
</person>
</genre>
</contact>
(4)從工具箱選擇TreeView控件和XmlDataSource控件設(shè)計(jì)頁面,把XmlDataSource控件DataFile屬性設(shè)置成“~/App_Data/XMLFile.xml”,并把TreeView控件的DataSourceID屬性設(shè)為“XmlDataSource1”。
(5)在首次加載頁面時,用編程的方式通過TreeNodeBinding對象添加節(jié)點(diǎn)與XML文檔綁定的對應(yīng)關(guān)系(也可以使用設(shè)計(jì)器指定)。代碼如下所示。
代碼如下:
<%@ Page Language="C#" AutoEventWireup="true" %>
<script runat="server">
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
this.TreeView1.ShowLines = true;
//以下是添加節(jié)點(diǎn)與數(shù)據(jù)源綁定的對應(yīng)關(guān)系
TreeNodeBinding contact = new TreeNodeBinding();
contact.DataMember = "contact";//指定綁定的成員
contact.ValueField = "name";//取值的字段
this.TreeView1.DataBindings.Add(contact);
TreeNodeBinding genre = new TreeNodeBinding();
genre.DataMember = "genre";//添加與"地區(qū)"綁定
genre.ValueField = "name";
this.TreeView1.DataBindings.Add(genre);
TreeNodeBinding person = new TreeNodeBinding();
person.DataMember = "person";//添加與"負(fù)責(zé)人"綁定
person.ValueField = "Text";
this.TreeView1.DataBindings.Add(person);
TreeNodeBinding name = new TreeNodeBinding();
name.DataMember = "name";//添加與"名稱"綁定
name.ValueField = "#InnerText";
this.TreeView1.DataBindings.Add(name);
TreeNodeBinding sex = new TreeNodeBinding();
sex.DataMember = "sex";//添加與"性別"綁定
sex.ValueField = "#InnerText";
this.TreeView1.DataBindings.Add(sex);
TreeNodeBinding age = new TreeNodeBinding();
age.DataMember = "age";//添加與"年齡"綁定
age.ValueField = "#InnerText";
this.TreeView1.DataBindings.Add(age);
TreeNodeBinding address = new TreeNodeBinding();
address.DataMember = "address";//添加與"地址"綁定
address.ValueField = "#InnerText";
this.TreeView1.DataBindings.Add(address);
}
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>TreeView綁定XML示例</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:XmlDataSource ID="XmlDataSource1" runat="server"
DataFile="~/App_Data/XMLFile.xml">
</asp:XmlDataSource>
</div>
<asp:TreeView ID="TreeView1" runat="server"
DataSourceID="XmlDataSource1">
</asp:TreeView>
</form>
</body>
</html>
(6)按Ctrl+F5組合鍵運(yùn)行程序,運(yùn)行結(jié)果下圖所示。
源程序解讀
(1)TreeNodeBinding類在TreeView控件中定義數(shù)據(jù)項(xiàng)與該數(shù)據(jù)項(xiàng)綁定到的節(jié)點(diǎn)之間的關(guān)系。該類的DataMember屬性指定在節(jié)點(diǎn)顯示的數(shù)據(jù)源對應(yīng)XML的節(jié)點(diǎn)。ValueField屬性對應(yīng)TreeNode對象的Value屬性。
(2)TreeNodeBinding類的Text屬性指定向用戶顯示的文本,如果該屬性沒有指定,則默認(rèn)與ValueField屬性相同。
(3)TreeView控件的DataSourceID屬性指定數(shù)據(jù)源控件源ID。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com