簡體   English   中英

JSF 2 中的錯誤與 Ajax 調用以根據請求參數更新部件

[英]Error in JSF 2 with Ajax call to update parts based on request parameters

我對JSF 2 很陌生。我正在嘗試使用 Ajax 渲染組件,具體取決於用戶選擇的復選框。 例如,復選框 1、框 2 和框 3。

每當我選擇一個復選框時,我都會遇到一些錯誤。

錯誤信息:

serverError: class javax.faces.component.UpdateModelException/ajaxcall.xhtml@27,
54 value="#{bean.panels}": Property 'panels' not writable on type java.util.List

下面是我的 XHTML 代碼。

<?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:ui="http://java.sun.com/jsf/facelets"
>
    <h:head><title>JSF 2.0: Blank Starting-Point Project</title>
    </h:head>

    <h:body>
        <h:panelGroup id="panels">
            <h:panelGroup rendered="#{bean.panels.contains('u1')}">
                panel one
            </h:panelGroup>
            <h:panelGroup rendered="#{bean.panels.contains('u2')}">
                panel two
            </h:panelGroup>
            <h:panelGroup rendered="#{bean.panels.contains('u3')}">
                panel three
            </h:panelGroup>
        </h:panelGroup>

        <h:form>
            <h:selectManyCheckbox value="#{bean.panels}">
                <f:selectItem itemValue="u1" />
                <f:selectItem itemValue="u2" />
                <f:selectItem itemValue="u3" />
                <f:ajax render=":panels" />
            </h:selectManyCheckbox>
        </h:form>
    </h:body>
</html>

這是我的豆子:

package somePackage;

import java.util.ArrayList;
import java.util.List;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;

@ManagedBean
@RequestScoped
public class Bean {
    private List<String> panels = new ArrayList<String>();

    public List<String> getPanels() {
        return panels;
    }
}

我錯過了什么嗎?

這個錯誤有點誤導,但你也需要一個二傳手。

public void setPanels(List<String> panels) {
    this.panels = panels;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM