在 XSLT 中创建一个简单的模式弹出 window
Create a simple modal pop-up window in XSLT
我正在构建一种风格 sheet,它在 table 中有一些成员。我想要的是,当我单击每个成员时,弹出模式 window 以打开 XML 文件中该成员的数据(我可以使用成员 ID 作为参考)。我尝试使用 fancybox (http://fancybox.net/),但问题是,这些成员是从 XML 动态填充的,当我单击一个成员时,它会打开弹出窗口,其中包含来自其他成员的数据。
XML
<Members>
<Member Name = “John Smith” MemberNumber = “JS001” DateofBirth = “09/01/1978” Gender = “Male”/>
<Member Name = “Andy Rodrigues” ” MemberNumber = “AR001” DateofBirth = “05/01/1970” Gender = “Male”/>
<Member Name = “Julie Dean” ” MemberNumber = “JD001” DateofBirth = “05/01/1970” Gender = “Male”/>
</Members>
**Stylesheet**
Member Name Member Number
[John Smith][1] JS001
[Andy Rodriguez][1] AR001
[Julie Dean][1] JD001
**Pop-up**
Member John Smith
Date of Birth 09/01/1978
Gender Male
样式中的会员姓名sheet 是应该打开带有会员信息(例如出生日期和性别)的弹出窗口的链接。
我使用 FancyBox 的代码示例:
<xsl:for-each select="Members/Member">
<tr>
<td>
<div class="indicator bck-belize-hole brd-peter-river">
<xsl:element name="a">
<xsl:attribute name="href">#inline_DTRXMLInfo</xsl:attribute>
<xsl:attribute name="class">various moreinfo whiteicon</xsl:attribute>
<xsl:value-of select="@Name"/>
</xsl:element>
</div>
<xsl:value-of select="@Name"/>
</td>
<td >
<font face="Arial" size="2" color="black">
<b>
<xsl:value-of select="@MemberNumber"/>
</b>
</font>
</td>
</tr>
</xsl:for-each>
<div class="fancynone">
<div id="inline_DTRXMLInfo" class="fancysize">
<xsl:call-template name="DTRXMLInfo">
<xsl:with-param name="Date Of Birth" select="DateofBirth"></xsl:with-param>
</xsl:call-template>
</div>
解决方案:
由于成员是动态添加到样式表中的,我们必须给 <div>
inline_DTRXMLInfo 一个唯一的 ID,可以通过将 MemberNumber 附加到 <div>
ID 来实现。
代码:
<xsl:attribute name="href">#inline_DTRXMLInfo_<xsl:value-of select="@MemberNumber"/></xsl:attribute>
<div id="inline_DTRXMLInfo_{$MemberNumber}" class="fancysize">
<xsl:call-template name="DTRXMLInfo">
<xsl:with-param name="Date Of Birth" select="DateofBirth"></xsl:with-param>
</xsl:call-template>
</div>
我正在构建一种风格 sheet,它在 table 中有一些成员。我想要的是,当我单击每个成员时,弹出模式 window 以打开 XML 文件中该成员的数据(我可以使用成员 ID 作为参考)。我尝试使用 fancybox (http://fancybox.net/),但问题是,这些成员是从 XML 动态填充的,当我单击一个成员时,它会打开弹出窗口,其中包含来自其他成员的数据。
XML
<Members>
<Member Name = “John Smith” MemberNumber = “JS001” DateofBirth = “09/01/1978” Gender = “Male”/>
<Member Name = “Andy Rodrigues” ” MemberNumber = “AR001” DateofBirth = “05/01/1970” Gender = “Male”/>
<Member Name = “Julie Dean” ” MemberNumber = “JD001” DateofBirth = “05/01/1970” Gender = “Male”/>
</Members>
**Stylesheet**
Member Name Member Number
[John Smith][1] JS001
[Andy Rodriguez][1] AR001
[Julie Dean][1] JD001
**Pop-up**
Member John Smith
Date of Birth 09/01/1978
Gender Male
样式中的会员姓名sheet 是应该打开带有会员信息(例如出生日期和性别)的弹出窗口的链接。
我使用 FancyBox 的代码示例:
<xsl:for-each select="Members/Member">
<tr>
<td>
<div class="indicator bck-belize-hole brd-peter-river">
<xsl:element name="a">
<xsl:attribute name="href">#inline_DTRXMLInfo</xsl:attribute>
<xsl:attribute name="class">various moreinfo whiteicon</xsl:attribute>
<xsl:value-of select="@Name"/>
</xsl:element>
</div>
<xsl:value-of select="@Name"/>
</td>
<td >
<font face="Arial" size="2" color="black">
<b>
<xsl:value-of select="@MemberNumber"/>
</b>
</font>
</td>
</tr>
</xsl:for-each>
<div class="fancynone">
<div id="inline_DTRXMLInfo" class="fancysize">
<xsl:call-template name="DTRXMLInfo">
<xsl:with-param name="Date Of Birth" select="DateofBirth"></xsl:with-param>
</xsl:call-template>
</div>
解决方案:
由于成员是动态添加到样式表中的,我们必须给 <div>
inline_DTRXMLInfo 一个唯一的 ID,可以通过将 MemberNumber 附加到 <div>
ID 来实现。
代码:
<xsl:attribute name="href">#inline_DTRXMLInfo_<xsl:value-of select="@MemberNumber"/></xsl:attribute>
<div id="inline_DTRXMLInfo_{$MemberNumber}" class="fancysize">
<xsl:call-template name="DTRXMLInfo">
<xsl:with-param name="Date Of Birth" select="DateofBirth"></xsl:with-param>
</xsl:call-template>
</div>