ASP.NET实现TreeView的XML数据源绑定

      TreeView控件可以使用XML文档作为数据源,根据XML文档的层次结构显示节点。而XML文档的访问由XmlDataSource控件来完成,从XmlDataSource控件的DataFile属性中指定XML文档路径,然后在TreeView控件中设置与XML文档中的节点的对应关系。本示例将演示如何把TreeView控件绑定到XML数据源。

技术要点
把TreeView控件绑定到XML数据源的技术要点如下。

使用XmlDataSource控件提供对XML文档的访问。

在TreeView控件的DataBindings属性中指定节点与XML文档的对应关系。
 

实现步骤

(1)在VS2008中创建一个ASP.NET网站,命名为“TreeViewSample2”。

(2)添加一个页面,命名为“TreeViewControl.aspx”,并把这个页设置为起始页。

(3)在“App_Data”文件夹中创建一个XML文档,命名为“XMLFile.xml”,该文档包含三层结构:联系人、地区和负责人。代码如下所示。

Code:
  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <contact name="联系人">
  3. <genre name="华南地区">
  4. <person Text="负责人">
  5. <name>张三</name>
  6. <sex></sex>
  7. <age>25</age>
  8. <address>广州市黄浦区</address>
  9. </person>
  10. <person Text="负责人">
  11. <name>李四</name>
  12. <sex></sex>
  13. <age>28</age>
  14. <address>佛山市南海区</address>
  15. </person>
  16. </genre>
  17. <genre name="华北地区">
  18. <person Text="负责人">
  19. <name>王五</name>
  20. <sex></sex>
  21. <age>30</age>
  22. <address>北京市海淀区</address>
  23. </person>
  24. </genre>
  25. </contact>

(4)从工具箱选择TreeView控件和XmlDataSource控件设计页面,把XmlDataSource控件DataFile属性设置成“~/App_Data/XMLFile.xml”,并把TreeView控件的DataSourceID属性设为“XmlDataSource1”。

(5)在首次加载页面时,用编程的方式通过TreeNodeBinding对象添加节点与XML文档绑定的对应关系(也可以使用设计器指定)。代码如下所示。

Code:
  1. <%@ Page Language="C#" AutoEventWireup="true" %>
  2. <script runat="server">
  3. protected void Page_Load(object sender, EventArgs e)
  4. {
  5.     if (!IsPostBack)
  6.     {
  7.         this.TreeView1.ShowLines = true;
  8.         //以下是添加节点与数据源绑定的对应关系
  9.         TreeNodeBinding contact = new TreeNodeBinding();
  10.         contact.DataMember = "contact";//指定绑定的成员
  11.         contact.ValueField = "name";//取值的字段
  12.         this.TreeView1.DataBindings.Add(contact);
  13.         TreeNodeBinding genre = new TreeNodeBinding();
  14.         genre.DataMember = "genre";//添加与"地区"绑定
  15.         genre.ValueField = "name";
  16.         this.TreeView1.DataBindings.Add(genre);
  17.         TreeNodeBinding person = new TreeNodeBinding();
  18.         person.DataMember = "person";//添加与"负责人"绑定
  19.         person.ValueField = "Text";
  20.         this.TreeView1.DataBindings.Add(person);
  21.         TreeNodeBinding name = new TreeNodeBinding();
  22.         name.DataMember = "name";//添加与"名称"绑定
  23.         name.ValueField = "#InnerText";
  24.         this.TreeView1.DataBindings.Add(name);
  25.         TreeNodeBinding sex = new TreeNodeBinding();
  26.         sex.DataMember = "sex";//添加与"性别"绑定
  27.         sex.ValueField = "#InnerText";
  28.         this.TreeView1.DataBindings.Add(sex);
  29.         TreeNodeBinding age = new TreeNodeBinding();
  30.         age.DataMember = "age";//添加与"年龄"绑定
  31.         age.ValueField = "#InnerText";
  32.         this.TreeView1.DataBindings.Add(age);
  33.         TreeNodeBinding address = new TreeNodeBinding();
  34.         address.DataMember = "address";//添加与"地址"绑定
  35.         address.ValueField = "#InnerText";
  36.         this.TreeView1.DataBindings.Add(address);
  37.     }
  38. }
  39. </script>
  40. <html xmlns="http://www.w3.org/1999/xhtml" >
  41. <head runat="server">
  42. <title>TreeView绑定XML示例</title>
  43. </head>
  44. <body>
  45. <form id="form1" runat="server">
  46. <div>
  47. <asp:XmlDataSource ID="XmlDataSource1" runat="server" 
  48. DataFile="~/App_Data/XMLFile.xml">
  49. </asp:XmlDataSource>
  50. </div>
  51. <asp:TreeView ID="TreeView1" runat="server" 
  52. DataSourceID="XmlDataSource1">
  53. </asp:TreeView>
  54. </form>
  55. </body>
  56. </html>

 

来源:http://www.52dotnet.net/text/575.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值