我有一个 JSF 页面,其中包含合作伙伴列表。
页面以默认和选择模式两种模式打开,由choiceMode请求参数设置。
当choiceMode
参数未定义时,它只是一个列表,我可以在其中单击一行,它将导航到包含该行详细信息的页面
如果choiceMode="1"
这意味着页面以<iframe>
, 嵌套在父窗口中打开
当用户单击一行时,它不会打开该行的页面,而是运行一个 JavaScript 将所选行参数发送到父窗口
问题是构建 JavaScript,当它是选择模式时使用。在默认模式下,它必须是 just ""
,但在选择模式下,它必须类似于
rowOnClick(5, "Partner #5")
如何在其中添加双引号?
我可以rowOnClick(5, Partner #5)
用方法构建(不带引号)之类的东西concat
,但引号似乎是一个问题。我试过了,"e;
但没有任何效果\'
\"
页面代码:
<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ez="http://java.sun.com/jsf/composite/ezcomp"
xmlns:c="http://java.sun.com/jsp/jstl/core">
<h:head>
<title>Partners</title>
<script>
function cellOnClick(id, name) {
parent.document.getElementById("form:parentId").value = id;
parent.document.getElementById("form:parentName").value = name;
}
</script>
</h:head>
<f:metadata>
<f:viewParam name="choiceMode" value="#{partnersManagedBean.choiceMode}"/>
</f:metadata>
<h:body>
<c:choose>
<c:when test="#{partnersManagedBean.choiceMode == '1'}">
<c:set var="onclick" value="cellOnClick"/>
</c:when>
<c:otherwise>
<c:set var="outcome" value="partner"/>
</c:otherwise>
</c:choose>
<h:dataTable value="#{partnersManagedBean.partnersList}" var="item">
<h:column>
<f:facet name="header">
Name
</f:facet>
<ez:cell id="name" value="#{item.value.name}" rowId="#{item.value.id}" rowName="#{item.value.name}" outcome="#{outcome}" onclick="#{onclick}"/>
</h:column>
</h:dataTable>
</h:body>
</html>
复合组件:
<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:cc="http://java.sun.com/jsf/composite"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html">
<cc:interface>
<cc:attribute name="value" required="true"/>
<cc:attribute name="rowId" required="true"/>
<cc:attribute name="rowName" required="true"/>
<cc:attribute name="outcome" default=""/>
<cc:attribute name="onclick" default=""/>
</cc:interface>
<cc:implementation>
<h:link id="nameLink"
outcome="#{cc.attrs.outcome}"
onclick="#{cc.attrs.onclick==''?'':cc.attrs.onclick.concat('(').concat(cc.attrs.rowId).concat(',"e;').concat(cc.attrs.rowName).concat('"e;)')}"
class="cell-link"
style="cursor: pointer">
<f:param name="id" value="#{cc.attrs.rowId}"/>
<div class="cell-div">
#{cc.attrs.value}
</div>
</h:link>
</cc:implementation>
</html>