gpt4 book ai didi

javascript - 动态改变h :dataTable value in JSF

转载 作者:行者123 更新时间:2023-12-02 18:32:06 28 4
gpt4 key购买 nike

如何动态更改 h:dataTable 的值?我有以下代码(只是一个片段):

        <h:dataTable value="#{DataProvider.mapValues}" var="o" border="1">
<h:column>
<h:outputText value="#{o.key}"></h:outputText>
</h:column>
<h:column>
<h:outputText value="#{o.value}"></h:outputText>
</h:column>
</h:dataTable>

<h:selectOneMenu>
<f:selectItem itemLabel="Choose Language.."></f:selectItem>
<f:selectItem itemLabel="DE"></f:selectItem>
<f:selectItem itemLabel="CZ"></f:selectItem>
<f:selectItem itemLabel="EN"></f:selectItem>
<f:selectItem itemLabel="FR"></f:selectItem>
<f:selectItem itemLabel="ES"></f:selectItem>
<f:selectItem itemLabel="PT"></f:selectItem>
</h:selectOneMenu>

所以,基本上,当我从 SelectOneMenu 中选择一种语言时,数据表应该使用不同的值(例如“#{DataProvider.mapValues(en)”)。需要明确的是:每次我从组合框中选择一个值时,数据表都应该使用其他值重新加载。

我想这可以与 JavaScript 一起使用,但我不知道它到底是如何完成的。任何帮助,将不胜感激。谢谢!

编辑:我必须使用 JSF1.2,因此我无法使用任何内置 AJAX 功能。

最佳答案

使DataProvider.getMapValues像这样:

private String selectedLanguage; // + getter and setter    

private Map getMapForLanguage(String language)
{ ... }

public Map getMapValues(){
return getMapForLanguage(selectedLanguage);
}

selectedLanguage 绑定(bind)到 h:selectOneMenu 选择的值,并在选择时对 h:dataTable 进行 ajax 更新,如下所示:

<h:dataTable id="myTable" ... >
...
<h:selectOneMenu value="#{DataProvider.selectedLanguage}">
...
<f:ajax render="myTable"/>
</h:selectOneMenu>

关于javascript - 动态改变h :dataTable value in JSF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17694254/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com