- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 XSLT 很陌生。我想在我的表格行中实现替代颜色。应该显示偶数行 - #EDF2F8 和奇数行 - #A7BFDE。
我有一个 xsl 看起来像:
<xsl:apply-templates select="records"/>
<xsl:template match="records">
<fo:table-row>
<fo:table-cell>
<xsl:value-of select="Firstname"/>
</fo:table-cell>
<fo:table-cell>
<xsl:value-of select="lastname"/>
</fo:table-cell>
<fo:table-cell>
<xsl:value-of select="Phone number"/>
</fo:table-cell>
</fo:table-row>
<xsl:variable name="css-class">
<xsl:choose>
<xsl:when test="position() mod 2 = 0">
<xsl:attribute name="bgcolor">#EDF2F8</xsl:attribute>
</xsl:when>
<xsl:otherwise>
<xsl:attribute name="bgcolor">#A7BFDE</xsl:attribute>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table-row class="{$css-class}">
<fo:table-cell>
<xsl:value-of select="Firstname"/>
</fo:table-cell>
<fo:table-cell>
<xsl:value-of select="lastname"/>
</fo:table-cell>
<fo:table-cell>
<xsl:value-of select="Phone number"/>
</fo:table-cell>
</fo:table-row>
<xsl:template match="records">
<xsl:variable name="bgclr">
<xsl:choose>
<xsl:when test="position() mod 2 = 0">#A7BFDE</xsl:when>
<xsl:otherwise>#EDF2F8</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table-row bgcolor="{$bgclr}">
<fo:table-cell padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="1.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="0.5pt">
<fo:block xmlns:st1="urn:schemas-microsoft-com:office:smarttags" space-after="10pt" space-after.conditionality="retain" line-height="1.4911" font-size="9pt" language="EN-US" text-align="left" font-weight="bold" linefeed-treatment="preserve">
<fo:leader leader-length="0pt"/>
<xsl:value-of select="name"/>
</fo:block>
</fo:table-cell>
"pdfrequest" : {
"records" : [{
"firstname" : "--",
"lastname" : "--",
"phoneno" : "--",
}]
}
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format" version="1.1" exclude-result-prefixes="fo">
<xsl:output method="xml" version="1.0" omit-xml-declaration="no" indent="yes"/>
<xsl:template match="pdfrequest">
<fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:w="http://schemas.microsoft.com/office/word/2003/wordml">
<fo:layout-master-set xmlns:rx="http://www.renderx.com/XSL/Extensions" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wx="http://schemas.microsoft.com/office/word/2003/auxHint" xmlns:aml="http://schemas.microsoft.com/aml/2001/core" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:dt="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882">
<fo:simple-page-master master-name="section1-first-page" page-width="12in" page-height="8.5in" margin-top="36pt" margin-bottom="36pt" margin-right="10pt" margin-left="10pt">
<fo:region-body margin-top="10pt" margin-bottom="70pt"/>
<fo:region-before region-name="first-page-header" extent="11in"/>
<fo:region-after region-name="first-page-footer" extent="11in" display-align="after"/>
</fo:simple-page-master>
<fo:simple-page-master master-name="section1-odd-page" page-width="12in" page-height="8.5in" margin-top="36pt" margin-bottom="36pt" margin-right="10pt" margin-left="10pt">
<fo:region-body margin-top="49pt" margin-bottom="61pt"/>
<fo:region-before region-name="odd-page-header" extent="11in"/>
<fo:region-after region-name="odd-page-footer" extent="11in" display-align="after"/>
</fo:simple-page-master>
<fo:simple-page-master master-name="section1-even-page" page-width="12in" page-height="8.5in" margin-top="36pt" margin-bottom="36pt" margin-right="10pt" margin-left="10pt">
<fo:region-body margin-top="49pt" margin-bottom="61pt"/>
<fo:region-before region-name="even-page-header" extent="11in"/>
<fo:region-after region-name="even-page-footer" extent="11in" display-align="after"/>
</fo:simple-page-master>
<fo:page-sequence-master master-name="section1-page-sequence-master">
<fo:single-page-master-reference master-reference="section1-first-page"/>
<fo:repeatable-page-master-alternatives>
<fo:conditional-page-master-reference odd-or-even="odd" master-reference="section1-odd-page"/>
<fo:conditional-page-master-reference odd-or-even="even" master-reference="section1-even-page"/>
</fo:repeatable-page-master-alternatives>
</fo:page-sequence-master>
</fo:layout-master-set>
<fo:page-sequence xmlns:rx="http://www.renderx.com/XSL/Extensions" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wx="http://schemas.microsoft.com/office/word/2003/auxHint" xmlns:aml="http://schemas.microsoft.com/aml/2001/core" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:dt="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882" master-reference="section1-page-sequence-master" format="1">
</fo:static-content>
<fo:static-content flow-name="xsl-footnote-separator">
<fo:block>
<fo:leader leader-pattern="rule" leader-length="144pt" rule-thickness="0.5pt" rule-style="solid" color="gray"/>
</fo:block>
</fo:static-content>
<fo:flow flow-name="xsl-region-body">
<fo:block widows="2" orphans="2" font-size="10pt" line-height="1.147" white-space-collapse="false">
<fo:marker xmlns:st1="urn:schemas-microsoft-com:office:smarttags" marker-class-name="first-page-header">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="11pt" language="EN-US" start-indent="-40.5pt">
<fo:leader/>
</fo:block>
</fo:marker>
<fo:marker xmlns:st1="urn:schemas-microsoft-com:office:smarttags" marker-class-name="first-page-footer">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="11pt" language="EN-US">
<fo:leader/>
</fo:block>
</fo:marker>
<fo:marker xmlns:st1="urn:schemas-microsoft-com:office:smarttags" marker-class-name="even-page-header"/>
<fo:marker xmlns:st1="urn:schemas-microsoft-com:office:smarttags" marker-class-name="even-page-footer"/>
<fo:block space-after="10pt" space-after.conditionality="retain" line-height="1.3190500000000002" font-size="16pt" language="EN-US" start-indent="0pt" space-before="18pt" space-before.conditionality="retain" font-weight="bold" color="#0070C0">
<fo:inline font-weight="bold" color="#0070C0" font-size="16pt">
<fo:leader leader-length="0pt"/>
Summary Report
</fo:inline>
</fo:block>
<fo:table xmlns:st1="urn:schemas-microsoft-com:office:smarttags" language="EN-US" start-indent="0pt" border-top-style="solid" border-top-color="#FFFFFF" border-top-width="1pt" border-left-style="solid" border-left-color="#FFFFFF" border-left-width="1pt" border-bottom-style="solid" border-bottom-color="#FFFFFF" border-bottom-width="1pt" border-right-style="solid" border-right-color="#FFFFFF" border-right-width="1pt" table-layout="fixed" table-omit-header-at-break="false">
<fo:table-column column-number="1" column-width="76.7pt"/>
<fo:table-column column-number="2" column-width="76.7pt"/>
<fo:table-column column-number="3" column-width="76.7pt"/>
<fo:table-header start-indent="0pt" end-indent="0pt">
<fo:table-row>
<fo:table-cell number-columns-spanned="9" padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="1.5pt" background-color="#4F81BD">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="9pt" language="EN-US" space-before="6pt" space-before.conditionality="retain" text-align="left" font-weight="bold" color="#FFFFFF">
<fo:inline font-weight="bold" color="#FFFFFF" font-size="9pt">
<fo:leader leader-length="0pt"/>
Section 1
</fo:inline>
</fo:block>
</fo:table-cell>
<fo:table-cell number-columns-spanned="2" padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="1.5pt" background-color="#4F81BD">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="9pt" language="EN-US" space-before="6pt" space-before.conditionality="retain" text-align="left" font-weight="bold" color="#FFFFFF">
<fo:inline font-weight="bold" color="#FFFFFF" font-size="9pt">
<fo:leader leader-length="0pt"/>
Section 2
</fo:inline>
</fo:block>
</fo:table-cell>
</fo:table-row>
<fo:table-row>
<fo:table-cell padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="1.5pt" background-color="#4F81BD">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="9pt" language="EN-US" space-before="6pt" space-before.conditionality="retain" text-align="left" font-weight="bold" color="#FFFFFF">
<fo:inline font-weight="bold" color="#FFFFFF" font-size="9pt">
<fo:leader leader-length="0pt"/>
Name
</fo:inline>
</fo:block>
</fo:table-cell>
<fo:table-cell padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="1.5pt" background-color="#4F81BD">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="9pt" language="EN-US" space-before="6pt" space-before.conditionality="retain" text-align="left" font-weight="bold" color="#FFFFFF">
<fo:inline font-weight="bold" color="#FFFFFF" font-size="9pt">
<fo:leader leader-length="0pt"/>
Phone no
</fo:inline>
</fo:block>
</fo:table-cell>
<fo:table-cell padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="1.5pt" background-color="#4F81BD">
<fo:block space-after="0pt" space-after.conditionality="retain" line-height="1.147" font-size="9pt" language="EN-US" space-before="6pt" space-before.conditionality="retain" text-align="left" font-weight="bold" color="#FFFFFF">
<fo:inline font-weight="bold" color="#FFFFFF" font-size="9pt">
<fo:leader leader-length="0pt"/>
Email
</fo:inline>
</fo:block>
</fo:table-cell>
</fo:table-row>
</fo:table-header>
<fo:table-body>
<xsl:template match="/pdfrequest">
<fo:root>
<xsl:apply-templates select="records"/>
</fo:root>
</xsl:template>
</fo:table-body>
</fo:table>
</fo:block>
</fo:flow>
</fo:page-sequence>
</fo:root>
</xsl:template>
<xsl:template match="records">
<xsl:variable name="bgclr">
<xsl:choose>
<xsl:when test="position() mod 2 = 0">#A7BFDE</xsl:when>
<xsl:otherwise>#EDF2F8</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table-row bgcolor="{$bgclr}">
<fo:table-cell padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="1.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="0.5pt">
<fo:block xmlns:st1="urn:schemas-microsoft-com:office:smarttags" space-after="10pt" space-after.conditionality="retain" line-height="1.4911" font-size="9pt" language="EN-US" text-align="left" font-weight="bold" linefeed-treatment="preserve">
<fo:leader leader-length="0pt"/>
<xsl:value-of select="firstname"/>
</fo:block>
</fo:table-cell>
<fo:table-cell padding-top="0pt" padding-left="0.1pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="0.5pt">
<fo:block xmlns:st1="urn:schemas-microsoft-com:office:smarttags" space-after="10pt" space-after.conditionality="retain" line-height="1.4911" font-size="9pt" language="EN-US" text-align="center" font-weight="bold" linefeed-treatment="preserve">
<fo:leader leader-length="0pt"/>
<xsl:value-of select="lastname"/>
</fo:block>
</fo:table-cell>
<fo:table-cell padding-top="0pt" padding-left="5.4pt" padding-bottom="0pt" padding-right="5.4pt" border-left-style="solid" border-right-style="solid" border-left-color="#FFFFFF" border-right-color="#FFFFFF" border-left-width="0.5pt" border-right-width="0.5pt" border-top-style="solid" border-bottom-style="solid" border-top-color="#FFFFFF" border-bottom-color="#FFFFFF" border-top-width="0.5pt" border-bottom-width="0.5pt">
<fo:block xmlns:st1="urn:schemas-microsoft-com:office:smarttags" space-after="10pt" space-after.conditionality="retain" line-height="1.4911" font-size="9pt" language="EN-US" text-align="left" font-weight="bold" linefeed-treatment="preserve">
<fo:leader leader-length="0pt"/>
<xsl:value-of select="phoneno"/>
</fo:block>
</fo:table-cell>
</fo:table-row>
</xsl:template>
</xsl:stylesheet>
最佳答案
尝试:
<xsl:variable name="bgclr">
<xsl:choose>
<xsl:when test="position() mod 2">#A7BFDE</xsl:when>
<xsl:otherwise>#EDF2F8</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table-row bgcolor="{$bgclr}">
...
<xsl:variable name="cls">
<xsl:choose>
<xsl:when test="position() mod 2">odd</xsl:when>
<xsl:otherwise>even</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table-row class="{$cls}">
...
<input>
<record>
<firstname>Adam</firstname>
<lastname>Adams</lastname>
<phonenumber>555-111</phonenumber>
</record>
<record>
<firstname>Betty</firstname>
<lastname>Blue</lastname>
<phonenumber>555-222</phonenumber>
</record>
<record>
<firstname>Cecil</firstname>
<lastname>Crawford</lastname>
<phonenumber>555-333</phonenumber>
</record>
</input>
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:fo="http://www.w3.org/1999/XSL/Format">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/input">
<fo:root>
<xsl:apply-templates select="record"/>
</fo:root>
</xsl:template>
<xsl:template match="record">
<xsl:variable name="bgclr">
<xsl:choose>
<xsl:when test="position() mod 2">#A7BFDE</xsl:when>
<xsl:otherwise>#EDF2F8</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table-row bgcolor="{$bgclr}">
<fo:table-cell>
<xsl:value-of select="firstname"/>
</fo:table-cell>
<fo:table-cell>
<xsl:value-of select="lastname"/>
</fo:table-cell>
<fo:table-cell>
<xsl:value-of select="phonenumber"/>
</fo:table-cell>
</fo:table-row>
</xsl:template>
</xsl:stylesheet>
<?xml version="1.0" encoding="UTF-8"?>
<fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format">
<fo:table-row bgcolor="#A7BFDE">
<fo:table-cell>Adam</fo:table-cell>
<fo:table-cell>Adams</fo:table-cell>
<fo:table-cell>555-111</fo:table-cell>
</fo:table-row>
<fo:table-row bgcolor="#EDF2F8">
<fo:table-cell>Betty</fo:table-cell>
<fo:table-cell>Blue</fo:table-cell>
<fo:table-cell>555-222</fo:table-cell>
</fo:table-row>
<fo:table-row bgcolor="#A7BFDE">
<fo:table-cell>Cecil</fo:table-cell>
<fo:table-cell>Crawford</fo:table-cell>
<fo:table-cell>555-333</fo:table-cell>
</fo:table-row>
</fo:root>
table-row
的交替背景颜色.
关于xslt - 在生成 pdf 时通过 XSL 替代表格行颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25341612/
我有一个 XSLT 样式表,如下所示: 我想使用第二个 XSLT 样式表来转换此样式表,以删除与 XQHead
我们有一个大型 xslt,可以呈现整个商店区域,包括产品、制造商,并根据价格和类别进行过滤。我使用 sitecore 作为 CMS,但遇到缓存问题。我有大约 9000 个项目,有些页面需要长达 20
我想根据条件的结果应用具有不同参数的模板。像这样: Attribute no. 1
我有一些看起来像这样的 XML Foo Details Bar Details Baz Details Foo Blah Bar BlahBlah Baz BlahBlahBl
我试图从这种输入出发: a b c d e f g ... 使用 XSLT 的 HTML 输出: one two a e b f
我想知道如何在 xslt 中找到特定节点的第一个子节点名称。 我有一个 xml: some text 我可以使用 body/
是否可以在 XSLT 中获取上个月的最后一天?我找到了这个函数:http://www.xsltfunctions.com/xsl/functx_last-day-of-month.html但我不确定如
具有特定节点的匹配元素存在问题。 xml: description of profile PhoneKeyPad S
我将一堆键值对作为参数传递给 XSL(日期 ->“1 月 20 日”,作者 ->“Dominic Rodger”,...)。 我正在解析的一些 XML 中引用了这些 - XML 如下所示: 目前,除
我找不到这个问题的确切答案,所以我希望有人能在这里帮助我。 我有一个字符串,我想在最后一个 '.' 之后获取子字符串。我正在使用 xslt 1.0。 这是怎么做的?这是我的代码。
我在尝试找出 xslt 上的 var 范围时遇到问题。我实际上想要做的是忽略具有重复“旅游代码”的“旅行”标签。 示例 XML: X1 Budapest X1 Budapest X
我有一些数据在 xslt 的 for-each 循环中输出。我对列表进行了分页,但没有对排序选择器进行分页。 用户应该能够对 2 个值(创建的数据和每个项目的数字字段)进行排序。默认的排序方法是创建日
我有一个奇怪的要求。 我在 xslt 中有一个包含月份的变量,带有它们的 id (1-12) 问题是我需要全部显示它们,但从一月(1)以外的月份开始。 目前我有以下 JAN
如何在 xslt 转换中模块化一组重复的输出?例如,我有如下内容(伪代码)。 并
我得到一个像这样的字符串。 13091711111100222222003333330044444400 字符串的模式是这样的 13 - 09 - 17 - 11111 - 100 - 22222 -
我是 XSLT 的新手,有一个一般性问题。为了区分具有不同属性的两个元素,最好(也是为了性能)使用 和 而不是 在一个模板中。据我所知,这就是 XSLT 中应该“思考”的方式。但在我看来,这有一个缺点
如何从“19650512-0065”到“196505120065”这样的字符串中删除连字符 使用这个模板:传递 theID =
是否有任何功能可以在左侧填充零? 我正在尝试做的要求是: 我们不知道即将到来的输入字符串长度。 如果小于 20,我们必须在左侧填充零。 如果输入字符串长度为 10,那么我们必须在左侧填充 10 个零。
身份模板如下所示: 是否选择多于 ,或者身份模板可能是这样的? 当我执行以下操作时,究竟选择了什么? 最佳答案
我正在尝试使用 XML 信息和 XSLT 模板创建超链接。这是 XML 源代码。 Among individual stocks, the top percentage gainers in the
我是一名优秀的程序员,十分优秀!