电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 在线教程-> .NET
xslt / xml / c#-.net教程,xml应
作者:网友供稿 点击:5
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
xslt / xml / c# (转)


这个例程展示了如何将xslt 应用于从数据库中读出的xml格式数据上. 例程完全使用c#语言编写:



using system;
using system.collections;
using system.data;
using system.data.sqlclient;
using system.xml;
using system.xml.xsl;

public class xslttransform
    {
        public static void transform()
        {
            sqlconnection nwindconn = new sqlconnection("data
            source=inmumis123;database=northwind;uid=sa;pwd=;");
            nwindconn.open();

            dataset custds = new dataset("customerdataset");

            sqldataadapter custda = new sqldataadapter("select * from customers",
            nwindconn);
            custda.fill(custds, "customers");

            sqldataadapter ordersda = new sqldataadapter("select * from orders",
            nwindconn);
            ordersda.fill(custds, "orders");

            nwindconn.close();

            custds.relations.add("custorders",
            custds.tables["customers"].columns["customerid"],
            custds.tables["orders"].columns["customerid"]).nested = true;

            xmldatadocument xmldoc = new xmldatadocument(custds);

            xsltransform xsltran = new xsltransform();
            xsltran.load("transform.xsl");

            // this is for generating the output in new html
            xmltextwriter writer = new xmltextwriter("xslt_output.html",
            system.text.encoding.utf8);
            writer.close();

            // this is for writing in the current page
            xsltran.transform(xmldoc, null, response.outputstream);

        }
}

 

上面这个称为xslttransform的类连接到一个数据库,将数据填充到xmldocument 中,然后将下面提供的xslt应用于这个xml.



<%@ page language="c#"%>
<!doctype html public "-//w3c//dtd html 4.0 transitional//en" >
<html>
    <head>
        <meta name="generator" content="microsoft visual studio 7.0">
        <meta name="code_language" content="c#">
        <meta name="vs_defaultclientscript" content="javascript (ecmascript)">
        <meta name="vs_targetschema" content="http://schemas.microsoft.com/intellisense/ie5">
    </head>

    <script>
    public void page_load(object sender, system.eventargs e)
    {
        transform();
    }
    public void transform()
    {
        sqlconnection nwindconn = new sqlconnection("data         
        source=inmumis123;database=northwind;uid=sa;pwd=;");
        nwindconn.open();

        dataset custds = new dataset("customerdataset");

        sqldataadapter custda = new sqldataadapter("select * from customers",
        nwindconn);
        custda.fill(custds, "customers");

        sqldataadapter ordersda = new sqldataadapter("select * from orders",
        nwindconn);
        ordersda.fill(custds, "orders");

        nwindconn.close();

        custds.relations.add("custorders",
        custds.tables["customers"].columns["customerid"],
        custds.tables["orders"].columns["customerid"]).nested = true;

        xmldatadocument xmldoc = new xmldatadocument(custds);

        xsltransform xsltran = new xsltransform();
        xsltran.load("transform.xsl");

        // xmltextwriter writer = new xmltextwriter("xslt_output.html",         
        system.text.encoding.utf8);

        xsltran.transform(xmldoc, null, response.outputstream);
        // writer.close();
    }
</script>

<body ms_positioning="gridlayout">
<form id="form1" method="post" runat="server">
</form>
</body>
</html>
 

上面的aspx page 用这个类(xslttranform)建立了一对象, 然后调用了transform 函数  





<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/xsl/transform" version="1.0">

<xsl:template match="customerorders">

    <style>
    body {font-family:verdana;font-size:9pt}
    td {font-size:8pt}
    </style>

        <table border="1">
            <xsl:apply-templates select="customers"/>
        </table>


</xsl:template>

<xsl:template match="customers">
    <tr><td>
        <xsl:value-of select="contactname"/>, <xsl:value-of select="phone"/><br/>
    </td></tr>
        <xsl:apply-templates select="orders"/>
</xsl:template>


<xsl:template match="orders">
    <table border="1">
        <tr><td valign="top"><b>order:</b></td><td valign="top"><xsl:value-of select="orderid"/></td></tr>
        <tr><td valign="top"><b>date:</b></td><td valign="top"><xsl:value-of select="orderdate"/></td></tr>
        <tr><td valign="top"><b>ship to:</b></td>
        <td valign="top"><xsl:value-of select="shipname"/><br/>
            <xsl:value-of select="shipaddress"/><br/>
            <xsl:value-of select="shipcity"/>, <xsl:value-of select="shipregion"/> <xsl:value-of select="shippostalcode"/><br/>
<xsl:value-of select="shipcountry"/></td></tr>
        </table>
</xsl:template>

</xsl:stylesheet>

 

最后是这个xslt 文件


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·经典收藏之 - C++内存管理详解-.NET教程,C#语言
·Master Page 初探-.NET教程,评论及其它
·GDI+编程10个基本技巧-.NET教程,评论及其它
·VB.NET中让Textbox只能输入数字(二)-.NET教程,VB.Net语言
·stl应用小问题-.NET教程,评论及其它
·WIN32中颜色值(COLORREF)与.NET中颜色值(Color)的转换-ASP教程,系统相关
·打造自己的专业图像工具-Visual C++ 2005图像编程系列【三】-.NET教程,C#语言
·.Net中常见问题及解决方法归类-.NET教程,.NET Framework
·Lex和Yacc从入门到精通(3)--一个极其简单的lex和yacc程序-.NET教程,评论及其它
·VB下几个非常有用的函数-.NET教程,VB.Net语言

最新文章
·VC#初学入门:第一个Windows程序
·ASP.NET 2.0-选用DataSet或DataReader
·用.net 处理xmlHttp发送异步请求
·asp.net创建文件夹的IO类的问题
·asp.net 2.0 中加密web.config 文件中的配置节
·关于ASP.NET调用JavaScript的实现
·如何实现ASP.NET网站个性化
·Acegi安全系统的配置-.NET教程,评论及其它
·Spring安全系统:Acegi Security Acegi简介-.NET教程,评论及其它
·Biztalk 开发之 架构和实例的验证-.NET教程,评论及其它




版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号