是否可以使用xslt访问查询字符串?
我有一个网址,例如
www.example.com/page.aspx?k=aa&lang=en
我想做点什么
如果lang = en
<div>displaly stuff</div>
Run Code Online (Sandbox Code Playgroud)
其他
<div>display other stuff</div>
Run Code Online (Sandbox Code Playgroud)
你能告诉我如何使用xslt做到这一点吗?
是否可以使用xslt访问查询字符串?
是,如果查询字符串作为参数传递.
下面的代码显示访问查询字符串不需要扩展功能.它可以作为(全局)参数传递.这是首选,因为它减少了对扩展的需求,并使代码更清晰,更易读.
然后可以执行标记化(tokenize()使用FXSL 1.xstr-split-to-words模板或自编写的递归标记化模板在XSLT 2.0或XSLT 1.0中使用该函数.)
XSLT 1.0解决方案:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:ext="http://exslt.org/common"
>
<xsl:import href="strSplit-to-Words.xsl"/>
<xsl:output indent="yes" omit-xml-declaration="yes"/>
<xsl:param name="pQString" select=
"'?login=userId&tag=XSLT&lang=en&level=expert'"
/>
<xsl:template match="/">
<xsl:variable name="vwordNodes">
<xsl:call-template name="str-split-to-words">
<xsl:with-param name="pStr" select="$pQString"/>
<xsl:with-param name="pDelimiters"
select="'?&'"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="vLang" select=
"substring-after(ext:node-set($vwordNodes)/*
[starts-with(.,'lang=')]
[last()],
'lang='
)
"/>
<xsl:value-of select="concat('lang = ', $vLang)"/>
</xsl:template>
</xsl:stylesheet>
Run Code Online (Sandbox Code Playgroud)
当上述转换应用于任何XML文档(不会被使用)时,生成所需的结果:
lang = en
Run Code Online (Sandbox Code Playgroud)
请注意 使用FXSL 1.x str-split-to-words模板和使用EXSLT ext:node-set()扩展功能.
XSLT 2.0解决方案:
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xsl:output indent="yes" omit-xml-declaration="yes"/>
<xsl:param name="pQString" as="xs:string" select=
"'?login=userId&tag=XSLT&lang=en&level=expert'"
/>
<xsl:template match="/">
<xsl:variable name="vLang" as="xs:string" select=
"substring-after(
tokenize($pQString, '\?|&')
[starts-with(.,'lang=')]
[last()],
'lang='
)
"/>
lang = "<xsl:sequence select='$vLang'/>"
</xsl:template>
</xsl:stylesheet>
Run Code Online (Sandbox Code Playgroud)
执行上述XSLT 2.0转换时,它会生成正确的结果:
lang = "en"
Run Code Online (Sandbox Code Playgroud)