1

多くの人にとっては簡単だと思いますが、何が間違っているのかわかりません。

私のコントローラー:

@RequestMapping(value = "/novo", method = RequestMethod.GET)
public ModelAndView novoTimeSheet() {

    Usuario usuario1 = new Usuario(1L,"Leandro1","ltsiciliano1@gmail.com");
    Usuario usuario2 = new Usuario(2L,"Leandro2","ltsiciliano2@gmail.com");
    Usuario usuario3 = new Usuario(3L,"Leandro3","ltsiciliano3@gmail.com");
    List<Usuario> usuarioList = new ArrayList<Usuario>();
    usuarioList.add(usuario1);
    usuarioList.add(usuario2);
    usuarioList.add(usuario3);

    Map<String, Object> model = new HashMap<String, Object>();
    model.put("usuarios", usuarioList);

    return new ModelAndView("timesheetcrud/novo", "timesheetcruddto", model);
}

それは働いています:

    <td>Usuário :</td>
    <td>
        <select id="usuarios" name="usuarios">
            <c:forEach items="${timesheetcruddto.usuarios}" var="usuario">
                <option value="${usuario.id}"><c:out value="${usuario.nome}"/></option>
            </c:forEach>
        </select>
    </td>

しかし、私は春のタグを使いたいので、これを置きます:

    <td>Usuário :</td>
    <td>
        <td>
            <form:select id="id_usuario" path="usuarios">
                <form:option value="0" label="--- Select ---" />
                <form:options items="${usuarioList}"/>
            </form:select>
        </td>
    </td>

それはうまくいきません:

        <td>
            <form:select id="id_usuario" path="usuarios">
                <form:option value="0" label="--- Select ---" />
                <form:options items="${usuarios}"/>
            </form:select>
        </td>

そしてそれは間違っています:

org.springframework.beans.NotReadablePropertyException: Invalid property 'usuarios' of bean class [java.util.HashMap]: Bean property 'usuarios' is not readable or has an invalid getter method: Does the return type of the getter match the parameter type of the setter?

JSTL の代わりにスプリング タグを使用する利点を知りたいです。

ありがとう

4

3 に答える 3

1

あなたはこのようにすることができます

<form:select path="usuarioList"> <form:options items="${usuarios}" /> </form:select>

于 2015-01-19T04:57:07.427 に答える
1

次のようにコードを改善できます

`<form:select path="usuarioList">
   <form:option value="NONE" label="--- Select ---"/>
   <form:options items="${usuarios}" />
</form:select>
`

また、変数名を次のようなより適切なものに変更してください

     List<Usuario> usuarios= new ArrayList<Usuario>();
    usuarios.add(usuario1);
    usuarios.add(usuario2);
    usuarios.add(usuario3);

    Map<String, Object> model = new HashMap<String, Object>();
    model.put("UserList", usuarios);

以前よりかなり良く見えます

于 2015-01-19T05:32:03.930 に答える