所属类别:.NET
文章作者:未知
特别推荐:免费发布信息 承包关键词~~抢爆了!HOT!
单位需要更新一下以前的新闻系统,需要与现代社会接轨,因此开始研究了一下XML来存储新闻的方法。找到了网上流传的一段很有名的读取XML文件作为新闻的方法,代码如下:<%@ Import Namespace="System"%><%@ Page Language="C#" Debug="true" codepage="936"%><%@ Import Namespace="System.IO" %><%@ Assembly Name="System.Xml" %><%@ Import Namespace="System.Xml.Xsl" %>public string xslt(){StringWriter writer = new StringWriter();XmlDocument xmldoc= new XmlDocument();xmldoc.Load(Server.MapPath(Request["name"] +".xml"));XslTransform xsldoc = new XslTransform();xsldoc.Load(Server.MapPath("main.xsl"));DocumentNavigator nav= new DocumentNavigator(xmldoc);xsldoc.Transform(nav,null,writer);return writer.ToString();}<%=xslt()%>该程序由www.aspcool.com设计制作.关键的地方就是:DocumentNavigator nav= new DocumentNavigator(xmldoc);这句话怎么都不能解释,郁闷了很久,找了最新的MSDN Lib结果找到一个2001年的MSDN 杂志上面的一段话:DocumentNavigator只能用于Asp.Net Beta2,痛苦,找了老半天,这段所谓经典的代码竟然是过时的产品。没有办法,只好从后一句想办法,找xsldoc.Transform(nav,null,writer);总算找到了Transform这个函数的用法,public XmlReaderTransform( XPathNavigatorinput, XsltArgumentListargs);然后就开始找XPathNavigator,不错,XmlDocument自己就带了一个CreateNavigator()函数。总算大功告成。修改后的代码:<%@ Import Namespace="System"%><%@ Page Language="C#" Debug="true" codepage="936"%><%@ Import Namespace="System.IO" %><%@ Assembly Name="System.Xml" %><%@ Import Namespace="System.Xml" %><%@ Import Namespace="System.Xml.Xsl" %><%@ Import Namespace="System.Xml.XPath" %>public string xslt(){StringWriter writer = new StringWriter();XmlDocument xmldoc= new XmlDocument();xmldoc.Load(Server.MapPath(Request["name"] +".xml"));XslTransform xsldoc = new XslTransform();xsldoc.Load(Server.MapPath("main.xsl"));XPathNavigator nav = xmldoc.CreateNavigator();xsldoc.Transform(nav,null,writer);return writer.ToString();}找了一个晚上的google都没有找到结果,还是要自己分析,希望这段代码可以在Google上让以后的人找到,以方便日后学习ASP.NET的同好不用花费太多的时间来思考,可以尽快地找到答案。关闭本页
相关信息· 程序员的灯下黑:坚持和良好心态近乎道
· 使u-boot支持yaffs2烧写
· 利用新浪股道全程掌控网页信息
· LinuxAid 网站配置实例(一)
103855
93109
