通过JSF中的JavaScript获取bean的更新值

时间:2015-04-23 03:30:23

标签: javascript jsf richfaces

我在itemComp.xhtml中有一个上下文菜单,如果我点击上下文菜单中的任何项目,将调用操作itemDisplay.refreshItems,并且在完成此操作后,将调用JavaScript函数showPanel()

itemComp.xhtml

<rich:contextMenu disableDefaultMenu="true" event="oncontextmenu" submitMode="ajax">
    <rich:menuItem disabled="true" style="color:black; font-weight:bold;" value="Items"/>
    <rich:menuSeparator/>

    <c:forEach items="#{itemDisplay.componentTypeMap.keySet}" var="itemValue">
        <rich:menuItem value="#{itemValue}"
                       rendered="#{(itemValue == 'Bags Report') or
                                   (itemValue == 'Chairs Report') or
                                   (itemValue == 'Tables Report')}"
                       action="#{itemDisplay.refreshItems}"
                       oncomplete="showPanel( '#{itemValue}','#{item.id}')">
        </rich:menuItem>
    </c:forEach>
</rich:contextMenu>

在itemDisplayBean.java的refreshItems()中,我将所有变量设置为true。

itemDisplayBean.java

private boolean availableBags = false;

public boolean getAvailableBags() {
    return this.availableBags;
}

public void setAvailableBags(boolean availableBags) {
    this.availableBags = availableBags;
}
private boolean availableBags = false;

public boolean getAvailableBags() {
    return this.availableBags;
}

public void setAvailableBags(boolean availableBags) {
    this.availableBags = availableBags;
}
private boolean availableChairs = false;

public boolean getAvailableChairs() {
    return this.availableChairs;
}

public void setAvailableChairs(boolean availableChairs) {
    this.availableChairs = availableChairs;
}
private boolean availableTables = false;

public boolean getAvailableTables() {
    return this.availableTables;
}

public void setAvailableTables(boolean availableTables) {
    this.availableTables = availableTables;
}

public String refreshItems() {
    setAvailableBags(true);
    setAvailableChairs(true);
    setAvailableTables(true);
}

在itemDisplay.xhtml中,我有以下JavaScript函数showPanel()

function showPanel(item, itemId) {

    if (item == 'Bags Report') {
        if (#{itemDisplay.availableBags})
            Richfaces.showModalPanel('bags');
        else
            alert('No bags Found');
    } else if (item == 'Chairs Report') {
        if (#{itemDisplay.availableChairs})
            Richfaces.showModalPanel('chairs');
        else
            alert('No Chairs Found');
    } else if (item == 'Tables Report') {
        if (#{itemDisplay.availableTables})
            Richfaces.showModalPanel('tables');
        else
            alert('No Tables Found');
    }
}

这里的问题是 - 在JavaScript函数中,我没有得到更新的支持bean值,因此availableBags(if( #{itemDisplay.availableBags} ))false(即使在支持bean中设置为true) ,并且没有显示面板。如果我刷新页面,那么我将从支持bean获取更新的值(if( #{itemDisplay.availableBags} )为true并显示面板。任何人都可以帮助我为什么我只获取更新的值刷新页面。

1 个答案:

答案 0 :(得分:0)

正如所指出的,当页面呈现并成为静态文本时,将评估EL表达式。

您可以使用@data,例如:

<rich:menuItem data="#{itemDisplay.availableBags}" 
    oncomplete="showPanel('#{itemValue}', event.data)" … >

event.data将包含属性的当前值(您甚至可以将其指向对象)。

编辑:在RichFaces 3.x中,JS参数只是data