gpt4 book ai didi

Spring 形式 :select multiple selected value?

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

我有这个编辑表单:

enter image description here

我希望选择用户的角色。如果这是一对多的关系,我知道我可以这样做:

        <form:label path="roles">Roles:</form:label>
<form:select multiple="true" path="roles">
<c:forEach items="${roles}" var="rol">
<c:choose>
<c:when
test="${usuarioEdit.rol.id ==rol.id}">
<option value="${rol.id}" selected="selected">${rol.nombre}</option>
</c:when>
<c:otherwise>
<option value="${rol.id}">${rol.nombre}</option>
</c:otherwise>
</c:choose>

</c:forEach>
</form:select>
<form:errors cssStyle="color:red" path="roles"></form:errors>

但这是一个多对多的关系。如何在编辑表单中选择选项?有简单的表格吗?

此代码有效,但我想知道 spring 是否提供任何便利:

<form:select multiple="true" path="roles">
<c:forEach items="${roles}" var="rol">
<c:set var="isSelected" value="false" />
<c:forEach items="${rolesUsu}" var="rolUsu">
<c:if test="${rolUsu.getRol().getId()==rol.id}">
<c:set var="isSelected" value="true" />
</c:if>
</c:forEach>
<c:choose>
<c:when test="${isSelected}">
<option value="${rol.id}" selected="selected">${rol.nombre}</option>
</c:when>
<c:otherwise>
<option value="${rol.id}">${rol.nombre}</option>
</c:otherwise>
</c:choose>
</c:forEach>
</form:select>

编辑:

在我的 Controller 中,我有:

@InitBinder
public void initBinder(WebDataBinder binder) {

binder.registerCustomEditor(Set.class, "roles",
new RolCollectionEditor(Set.class, rolDao));

}

RolCollectionEditor:

public class RolCollectionEditor extends CustomCollectionEditor {

private final RolDAO rolDao;


public RolCollectionEditor(Class<?> collectionType, RolDAO rolDao) {

super(collectionType);
this.rolDao = rolDao;

}

@Override
protected Object convertElement(Object element) {
String rolId = (String) element;

Rol rol = rolDao.findById(rolId);
Usuario_Rol usuRol = new Usuario_Rol();

//Agregamos un usuario vacio temporal
//y lo sobreescribimos en el controlador
Usuario usuario = new Usuario();

usuRol.setUsuario(usuario);
usuRol.setRol(rol);
usuRol.setFechaCreacion(new Date());
usuRol.setFechaModificacion(new Date());
usuRol.setStatus("activo");

return usuRol;
}

}

这里 Usuario_Rol 是多对多关系的中间表,除了 userId 和 rolId 之外还有其他属性。

编辑2:

角色类:

@Entity
@Table(name = "rol", uniqueConstraints = { @UniqueConstraint(columnNames = "nombre") })
public class Rol implements Serializable{

@Id
@Column(name = "_id")
private String id;

@Column(name = "nombre")
@NotNull
private String nombre;

@Column(name = "descripcion")
private String descripcion;

@Column(name = "status")
private String status;

@Column(name = "fechaCreacion")
private Date fechaCreacion;

@Column(name = "fechaModificacion")
private Date fechaModificacion;

@Column(name = "fechaSincronizacion")
private Date fechaSincronizacion;

@OneToMany(fetch = FetchType.EAGER, mappedBy = "usuarioRol_pk.rol", orphanRemoval = true, cascade=CascadeType.ALL)
private Set<Usuario_Rol> usuarios = new HashSet<Usuario_Rol>(0);


//getters and setters

@Override
final public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((nombre == null) ? 0 : nombre.hashCode());
return result;
}

@Override
final public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (!(obj instanceof Rol))
return false;
Rol other = (Rol) obj;
if (nombre == null) {
if (other.nombre != null)
return false;
} else if (!nombre.equals(other.nombre))
return false;
return true;
}

类Usuario:

@实体@Table(name = "usuario", uniqueConstraints = { @UniqueConstraint(columnNames = "登录"), @UniqueConstraint(columnNames = "correo") })公共(public)类 Usuario 实现 Serializable {

@Id
@Column(name = "_id")
private String id;

@Column(name = "nombre")
@NotEmpty
private String nombre;

@Column(name = "apellido")
@NotEmpty
private String apellido;

@Column(name = "login")
@Size(min = 4)
@NotEmpty
private String login;

@Column(name = "password")
@NotEmpty
@Size(min = 4)
private String password;

@Column(name = "salt")
private String salt;

@Column(name = "correo")
@NotEmpty
@Email
private String correo;

@Column(name = "token")
private String token;

@Column(name = "status")
private String status;

@Column(name = "fechaUltimoLogin")
private Date fechaUltimoLogin;

@Column(name = "fechaCreacion")
private Date fechaCreacion;

@Column(name = "fechaModificacion")
private Date fechaModificacion;

@Column(name = "fechaSincronizacion")
private Date fechaSincronizacion;

@NotEmpty
@OneToMany(fetch = FetchType.EAGER, mappedBy = "usuarioRol_pk.usuario", orphanRemoval = true, cascade = CascadeType.ALL)
private Set<Usuario_Rol> roles = new HashSet<Usuario_Rol>(0);


//constructor, getters and setters.

@Override
final public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((login == null) ? 0 : login.hashCode());
return result;
}

@Override
final public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (!(obj instanceof Usuario))
return false;
Usuario other = (Usuario) obj;
if (login == null) {
if (other.login != null)
return false;
} else if (!login.equals(other.login))
return false;
return true;
}

中级:

@Entity
@Table(name = "usuario_rol")
@AssociationOverrides({
@AssociationOverride(name = "usuarioRol_pk.usuario", joinColumns = @JoinColumn(name = "idUsuario")),
@AssociationOverride(name = "usuarioRol_pk.rol", joinColumns = @JoinColumn(name = "idRol"))
})
public class Usuario_Rol implements Serializable{

@EmbeddedId
private Usuario_RolId usuarioRol_pk = new Usuario_RolId();

@Temporal(TemporalType.DATE)
@Column(name = "fechaCreacion")
private Date fechaCreacion;

@Temporal(TemporalType.DATE)
@Column(name = "fechaModificacion")
private Date fechaModificacion;

@Temporal(TemporalType.DATE)
@Column(name = "fechaSincronizacion")
private Date fechaSincronizacion;

@Column(name = "status")
private String status;

//gettters, setters

@Override
final public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((usuarioRol_pk == null) ? 0 : usuarioRol_pk.hashCode());
return result;
}


@Override
final public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (!(obj instanceof Usuario_Rol))
return false;
Usuario_Rol other = (Usuario_Rol) obj;
if (usuarioRol_pk == null) {
if (other.usuarioRol_pk != null)
return false;
} else if (!usuarioRol_pk.equals(other.usuarioRol_pk))
return false;
return true;
}

Usuario_RolId:

@Embeddable
public class Usuario_RolId implements Serializable{

@ManyToOne
private Usuario usuario;

@ManyToOne
private Rol rol;

public Usuario getUsuario() {
return usuario;
}
public void setUsuario(Usuario usuario) {
this.usuario = usuario;
}
public Rol getRol() {
return rol;
}
public void setRol(Rol rol) {
this.rol = rol;
}


@Override
final public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((rol == null) ? 0 : rol.hashCode());
result = prime * result + ((usuario == null) ? 0 : usuario.hashCode());
return result;
}

@Override
final public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (!(obj instanceof Usuario_RolId))
return false;
Usuario_RolId other = (Usuario_RolId) obj;
if (rol == null) {
if (other.rol != null)
return false;
} else if (!rol.equals(other.rol))
return false;
if (usuario == null) {
if (other.usuario != null)
return false;
} else if (!usuario.equals(other.usuario))
return false;
return true;
}

最后一个类用于模拟多对多关系的技巧。我已遵循本教程:http://www.mkyong.com/hibernate/hibernate-many-to-many-example-join-table-extra-column-annotation/

最佳答案

你为什么要自己写? Spring 应该能够为您做到这一点。而不是 <c:forEach /><form options .. /> 替换整个 block 标签。然后 Spring 将能够自己进行选择(您可能需要 ConverterPropertyEditor)。

<form:select multiple="true" path="roles" items="${roles}" itemLabel="nombre" itemValue="id" />

类似的东西......

链接:

  1. 表单选项documentation
  2. 表单选择documentation
  3. Reference Guide

关于 Spring 形式 :select multiple selected value?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18728678/

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