这是我的问题的流程:我有一个模态对话框,当我打开一个新对话框时,它会在模态对话框中打开 contentOne.jsp。当我单击 contentOne.jsp 上的链接时,模式对话框会刷新并使用我的 href 引用打开 contentTwo.jsp。然后我关闭对话框。当我再次打开对话框时,它会打开 contentTwo.jsp 而不是 contentOne.jsp。我尝试了destroyDescendants、destroyRendering....但它们没有用。
我有一个标题,其中包含一个打开模式对话框的链接,如下所示:
<div style="position: relative;right: 50px; top: 15px;">
<a onclick="dijit.byId('selectEquipmentInfo').show(); return false;" href="" />Add Equipment</a>
</div>
<%-- start equipment info dialog link --%>
<div id="selectEquipmentInfo" style="display:none;" name="selectEquipmentInfo" dojotype="dijit.Dialog" draggable="false" title="Select Equipment">
<div style="width:870px; height:400px; padding: 10px; overflow-y:auto;" href="">
<%@ include file="../../StoreInfoArea/ProductFamilyDisplay.jspf"%>
</div>
</div>
这应该打开一个模式对话框。在我的 ProductFamilyDisplay.jspf 中,我有一个项目链接到“href”上的另一个 jsp 页面,如下所示
<div id="productFamily" class="productFamilyContainer">
<div id= "prdctFamilyRow" class="productFamilyColumn">
<c:forEach var="equipmentInfo" items="${equipmentTestList}" varStatus="status">
<a href="${EquipmentModelsViewURL}"><c:out value="${equipmentInfo.value}" /></a><br />
</c:forEach>
</div>
这将在同一个模态对话框上呈现,并且由这个 javascript 控制:
<script type="text/javascript">
dojo.addOnLoad (function(event){
dojo.connect(dijit.byId('selectEquipmentInfo'), 'onClick', clicked);
});
var clicked=function(event) {
var dialog=dijit.byId('selectEquipmentInfo');
var contentNode=dialog.domNode;
var node = event.target;
var attrId = dojo.attr(node, "id");
if (attrId =="dijitCloseLink" || attrId == "dijitCloseImg") {
dialog.set('href','');
} else {
if("a" == node.nodeName.toLowerCase()){
dialog.href=node.href;
dialog.refresh();
dojo.stopEvent(event);
}
}
};
</script>