采用XML数据来填充ASP表单_Xml教程
推荐:如何建立一个 XML 的开发环境学习 XML 的最佳途经是从简单的开发入手,大胆实践,循序渐进。XML 的妙处只有在开发过程中才能深入体会,离开了开发是学不好 XML 的。因此学习 XML 首先应该建立一个 XML 的开发环境。我给大家
在本篇文章里,我们会使用一个简单的Web表单,它会列出某个目录下的一些XML文件。然后,我们会从这个目录里选择一个文件,将它发送到另一个Web表单里,后
者会使用被选中的XML文件来填充某些文本字段。
示例XML
我们的示例XML文档包含有一组含有基本信息的元素,如
Listing A所示:
以下为引用的内容: Listing A: sample.xml <Sample> <Name>John Doe</Name> <Address>900 N. Michigan Ave</Address> <City>Chicago</City> <State>IL</State> <Zip>60614</Zip> <Phone>630-555-5555</Phone> </Sample> |
为了让本文的说明更加有趣,我们会再创建两个含有不同数据的示例文件,如Listing B和Listing C所示:
以下为引用的内容: <Sample> Listing C: sample3.xml |
创建一个叫做C:\xmldocs的目录,并将所有三个示例文件放到这个目录下。
Web表单
我们会为我们的应用程序创建两个Web表单。我们要用第一个表单来选择XML文件,用第二个表单来显示XML数据。
首先要用Visual Studio .NET创建一个新的ASP.NET Web应用程序。然后将最初的表单保存为SelectFile.aspx。如果你双击这个表单,代码编辑器就会被打开。
你首先需要把下面这一行加到代码的最前面,才能够将IO包添加到你的应用程序里:
usingSystem.IO;
然后,找到代码内的Page_Load()方法。你需要将这个方法编辑成像下面Listing D里的代码一样:
以下为引用的内容: dir = new DirectoryInfo ("C:\\xmldocs"); while (fileEnum.MoveNext()) { |
现在向你的项目里添加一个新的Web表单——ShowData.aspx。在这个表单里放置六个文本框,并将其命名为:txtName、txtAddress、txtCity、txtState、txtZip和txtPhone。同样的,在表单里创建六个标签,并将其标题栏分别命名为Name(姓名)、Address(地址)、City(城市)、State(州)、Zip(邮政编码)和Phone(电话)。
双击ShowData表单来启动代码编辑器。你需要编辑ShowData表单的Page_Load()方法,使其看起来就像Listing E里的一样:
以下为引用的内容: filename = "C:\\xmldocs\\" Request.Params.Get("filename"); while (xmlReader.Read()) { |
你还需要把下面这一行加到代码的最前面,才能够将XML包添加到你的应用程序里:
usingSystem.Xml;
这段代码在本质上同我们在C#表单例子里所使用的代码相同。其主要的不同之处在于,我们不再利用按钮来调用这段代码,而且我们也不再需要使用OpenFileDialog控件来寻找XML文件。文件名是由SelectFile的Web表单所提供的,这段代码在ShowData表单被加载的时候被调用。
我们使用XmlTextReaders Read()方法在XML文档里迭代。随着每次对Read()的调用,我们都会处理另一个XML节点。我们只用简单地检查一下,以确保该节点是一个元素,然后就可以使用XML元素节点里的字符串数据来填充我们表格里相应的文本框了。
运行演示程序
一旦你完成了演示表单的编码和编译,你就已经准备好使用它们了。将你的Web浏览器指向SelectFile表单。当页面被载入的时候,它就应该能够列出我们先前创建的示例文件了。只用简单地点击其中一个文件名,你就会看到数据填充在ShowData表单里。
分享:使用xml作为数据源,让asp:Menu类自由扩展菜单项 先新建一个名为menu的xml文件,内容如下: <?xml version=1.0 encoding=utf-8 ?> <menu> <menuItem url=~/Default.aspx title=首页 description=/>
- 相关链接:
- 教程说明:
Xml教程-采用XML数据来填充ASP表单。