如何让xslt样式表接受参数

我们经常会有这样的需求:有多份数据,需要共享一份样式表来转换。他们的 区别可能就在于顶部会有一些小的差异,那么如何解决这个事情呢?

1. 在XSLT中定义参数

<?xml version="1.0" encoding="utf- 8"?>
<xsl:stylesheet version="1.0"  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt"  exclude-result-prefixes="msxsl"
>
    <xsl:output method="xml"  indent="yes"/>
    <xsl:param name="Title"></xsl:param>
  <xsl:template match="/">
      <html>
        <head></head>
        <body>
          <h1>
            <xsl:value-of  select="$Title"/>
          </h1>
        </body>
      </html>
    </xsl:template>
</xsl:stylesheet>

2. 在客户端代码中传递一个参数过来

using System;
using System.Collections.Generic;
using System.Text;
using System.Xml.Xsl;
using System.Xml.XPath;
using System.Xml;
using System.IO;
namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            XmlDocument doc = new XmlDocument();
            doc.LoadXml ("<Tables><Table><Name>Orders</Name></T able></Tables>");
            XslCompiledTransform tran = new  XslCompiledTransform();
            tran.Load("Test.xslt");
            XsltArgumentList a = new XsltArgumentList ();
            a.AddParam("Title", string.Empty,  "陈希章的报告");
            FileStream stream = new FileStream ("Test.htm", FileMode.Create);
            tran.Transform(doc.CreateNavigator(), a,  stream);
            stream.Close();
        }
    }
}

时间: 2024-10-24 18:38:30

如何让xslt样式表接受参数的相关文章

运行时将数据与XSLT样式表集成

本文描述了一种用于进行下列操作的机制:分别开发应用程序业务数据和表示数据,然后使用通用的 XSLT 样式表将它们组合在一起.应用程序业务数据被格式化成 XML 形式,而表示数据可以用传统工具来创建.附加属性增强了表示数据,样式表使用这些属性来将表示细节应用于实际内容.对于最终格式的创建,不需要专门的编程,因为这个过程是由 XSLT 处理器完成的. 为最充分地理解本文,您应该了解 XML 和 XSLT 的基础知识.请参阅 参考资料一节,以获得至可作为这些主题介绍的教程和文章的链接.这里显示的所有示

利用客户端XSLT样式表转换xml文档

源xml文档和那两个xslt样式表我没有提供哦,大家自己写写算了<html><head><style type="text/css">body {font-family:Tahoma,Verdana,Arial,sans-serif; font-size:14px}.head {font-family:Tahoma,Verdana,Arial,sans-serif; font-size:18px; font-weight:bold}</styl

将XSLT作为HTML的样式表的使用方法示例

 简介 当听到样式表这个词时,您可能会想到 CSS 样式表.XSLT 样式表通常用于 XML 转换,比如在 Web 服务之间映射数据.因为 XSLT 非常适合此用途,所以创建了顶层元素 <stylesheet> 的 <xsl:transform> 别名,虽然这很少使用.这种 XSLT 转换的输入结构与输出结构有很大的不同.最重要的是,命名空间的不同. XSLT 样式表的输入结构与输出结构相似,但却更简单些.其中已经扩充了一些标记,但大部分标记只是原样复制到输出.输入和输出的命名空间

深入XSLT第三章 --- 样式表结构

深入XSLT第三章 --- 样式表结构 在XML文件中样式表用元素xsl:stylesheet来表示. XSL处理器处理源文件和样式表时都必须采用XML的名域(Namespace)机制[W3C XML Names].所有XSL定义的元素(在文件中带有前缀xsl)只有是属于URI为http://www.w3.org/TR/WD-xsl中的某一个名域时才会被XSL识别; XSL 定义的元素只是在样式表中才认得,而并不是在源文件中.  xsl:stylesheet元素有一项可选的属性result-ns

深入XSLT第六章--- 联合样式表

深入XSLT第六章--- 联合样式表 XSL提供两种机制来联合样式表: 1.样式表导入,允许样式表之间相互引用2.样式表包含,允许样式表被原文组合. 样式表导入 一个XSL样式表可以包含xsl:import元素.所有xsl:import元素必须出现在样式表的开头. xsl:import元素有一个 href 属性,它的值就表示要导入的样式表的URI. 相对URI是指相对于xsl:import元素的基URI. <xsl:stylesheet xmlns:xsl="http://www.w3.o

菜鸟级:CSS样式表参数属性列表大全

css|样式表 属性名称字体属性(Font)font-familyfont-stylefont-variantfont-weightfont-size 颜色和背景属性ColorBackground-colorBackground-imageBackground-repeatBackground-attachmentBackground-position 文本属性Word-spacingLetter-spacingText-decoration Vertical-align Text-transf

jQuery CSS()方法改变现有的CSS样式表

  使用CSS()方法改变现有的CSS样式表,css()方法在使用上具有多样性.其中有一种可接受两个输入参数:样式属性和样式值,两者之间用逗号分隔.比如要改变链接颜色,可以这样编写代码: 1$("#61dh a").css('color','#123456'); 2//选择器'$("#61dh a")'表示ID为'#61dh'的元素下的所有链接. 3//.css('color','#123456');表示把颜色设为'#123456' 如果需要改变多个样式属性,可先定

jQuery CSS()方法改变现有的CSS样式表_jquery

使用CSS()方法改变现有的CSS样式表,css()方法在使用上具有多样性.其中有一种可接受两个输入参数:样式属性和样式值,两者之间用逗号分隔.比如要改变链接颜色,可以这样编写代码: $("#61dh a").css('color','#123456'); //选择器'$("#61dh a")'表示ID为'#61dh'的元素下的所有链接. //.css('color','#123456');表示把颜色设为'#123456' 如果需要改变多个样式属性,可先定义属性变量

JS函数实现动态添加CSS样式表文件_基础知识

先给出函数. 复制代码 代码如下: varaddSheet=function(){ vardoc,cssCode; if(arguments.length==1){ doc=document; cssCode=arguments[0] }elseif(arguments.length==2){ doc=arguments[0]; cssCode=arguments[1]; }else{ alert("addSheet函数最多接受两个参数!"); } if(!+"v1"