我正在创建一个XSL页面,我想在其中调用模式弹出窗口。 以下是我的XSL文件的一部分:
<xsl:if test="(/ShoppingBag/Multibuy/Discount) > 0">
<tr>
<td class="sbTotalsColLeft saving">
DiscountDetails
</td>
<td class="sbTotalsColRight">
</td>
</tr>
</xsl:if>
我想做的是当客户点击DiscountDetails时我想显示一个带有以下信息的模态弹出窗口
<table class="tbpromotionTypes">
<xsl:for-each select="/ShoppingBag/MultibuyDiscountedPromotionTypes/PromotionType">
<tr>
<td class="ptLeft ">
<xsl:value-of select ="./PromotionHeading"/>
</td>
<td class="ptRight">
<xsl:value-of select="./DiscountedPrice"/>
</td>
</tr>
</xsl:for-each>
</table>
答案 0 :(得分:0)
XSLT没有弹出窗口或点击的概念。
您可以使用xsl:messsage
将文本记录到控制台。
您可以根据需要将XML转换为HTML,包括JavaScript,以创建一个页面,其中模式对话框和点击是可操作的概念。
对于此输入样本文件:
<?xml version="1.0" encoding="UTF-8"?>
<ShoppingBag>
<MultibuyDiscountedPromotionTypes>
<PromotionType>
<PromotionHeading>Bread</PromotionHeading>
<DiscountedPrice>$1</DiscountedPrice>
</PromotionType>
<PromotionType>
<PromotionHeading>Eggs</PromotionHeading>
<DiscountedPrice>$2</DiscountedPrice>
</PromotionType>
<PromotionType>
<PromotionHeading>Milk</PromotionHeading>
<DiscountedPrice>$2</DiscountedPrice>
</PromotionType>
</MultibuyDiscountedPromotionTypes>
</ShoppingBag>
此XSLT脚本:
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" indent="yes"/>
<xsl:template match="/">
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Dialog - Default functionality</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<script>
$(function() {
$( "#dialog" ).dialog({autoopen: false});
$( "#dialog" ).dialog("close");
});
$(document).ready(function() {
$('#discountDetailsId').click(function() {
$( "#dialog" ).dialog({ modal: true });
});
});
</script>
</head>
<body>
<table>
<tr>
<td id="discountDetailsId">DiscountDetails</td>
</tr>
</table>
<div id="dialog" title="Discount Details">
<table class="tbpromotionTypes">
<xsl:for-each select="/ShoppingBag/MultibuyDiscountedPromotionTypes/PromotionType">
<tr>
<td class="ptLeft ">
<xsl:value-of select ="./PromotionHeading"/>
</td>
<td class="ptRight">
<xsl:value-of select="./DiscountedPrice"/>
</td>
</tr>
</xsl:for-each>
</table>
</div>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
制作此HTML文件(jsfiddle.net):
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta charset="utf-8">
<title>jQuery UI Dialog - Default functionality</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css"><script src="http://code.jquery.com/jquery-1.9.1.js"></script><script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script><link rel="stylesheet" href="/resources/demos/style.css"><script>
$(function() {
$( "#dialog" ).dialog({autoopen: false});
$( "#dialog" ).dialog("close");
});
$(document).ready(function() {
$('#discountDetailsId').click(function() {
$( "#dialog" ).dialog({ modal: true });
});
});
</script></head>
<body>
<table>
<tr>
<td id="discountDetailsId">DiscountDetails</td>
</tr>
</table>
<div id="dialog" title="Discount Details">
<table class="tbpromotionTypes">
<tr>
<td class="ptLeft ">Bread</td>
<td class="ptRight">$1</td>
</tr>
<tr>
<td class="ptLeft ">Eggs</td>
<td class="ptRight">$2</td>
</tr>
<tr>
<td class="ptLeft ">Milk</td>
<td class="ptRight">$2</td>
</tr>
</table>
</div>
</body>
</html>
这样当您按要求点击DiscountDetails时,会显示一个模态对话框。
答案 1 :(得分:-1)
建议:使用td类“sbTotalsColLeft”或“保存”JQuery来显示模型弹出窗口
$(".sbTotalsColLeft").Click(...... modal popup code here ....);