我的问题是我正在尝试在我的数据表中显示一个默认的输出文本列,并在按下命令按钮时用输入文本替换它。还没有找到解决方案。顺便提一句。
我有一个a4j:commandButton,我正在寻找reRender这部分数据表
<a4j:commandButton reRender="yieldTable" action="#{yieldSearch.activateVisible()}"
id="modify" styleClass="editLargeIcon" value="Modify">
</a4j:commandButton>
<rich:dataTable id="yieldTable" value="#{yieldSearch.yfitem.yielditem}" var="_yield">
<rich:column>
<f:facet name="header">%-YLD</f:facet>
<h:outputText value="#{_yield.yfYield}" rendered="#{not yieldSearch.visible}">
</h:outputText>
<h:inputText rendered="#{yieldSearch.visible}" />
</rich:column>
我想激活这个方法(只显示相关代码)
@Name("yieldSearch")
@Scope(ScopeType.CONVERSATION)
public class YieldSearch implements Serializable{
private Boolean visible;
public void activateVisible(){
this.setVisible(true);
System.out.print(true);
}
public void setVisible(Boolean visible) {
this.visible = visible;
}
public Boolean getVisible() {
return visible;
}
任何帮助都非常感激。
答案 0 :(得分:5)
您需要将这两个组件包装在<a4j:outputPanel id="myPanel" ajaxRendered="true"/>
中。两个组件无法重新生成的原因是您在初始视图呈现时不会将设置为rendered="false"
的组件发送到浏览器。
<a4j:outputPanel id="myPanel" ajaxRendered="true">
<h:outputText value="#{_yield.yfYield}" rendered="#{not yieldSearch.visible}"/>
<h:inputText rendered="#{yieldSearch.visible}" />
</a4j:outputPanel>
ajax刷新工作的方式是使用javascript在DOM树中定位clientId以使用新标记进行更新,即组件必须已经在DOM树中。由于您已设置rendered="false"
,因此组件永远不会在DOM树中开始。所以在ajax请求中,浏览器不知道你在说什么,因为它找不到要更新的clientId。
使用带有ajaxRendered="true"
的outputPanel,您将刷新整个outputPanel,因此ajax刷新将整个组件更新,无论您嵌套在其中的是什么