在jsp页面要实现这样一个功能,列表的某一列字段要显示的数据,是从后台的一个列表中获取的,数据库里面该列存储的方式是 相似 1,2,3 这样的 主键id数据。显示的时候要根据id显示名称,若是是多个 则要逗号分隔这种。数据库
第一次是这样实现的:jsp
<c:forEach var="cooperation" items="${cooperationTypeList}"> <c:if test="${fn:contains(entity.cooperationId,cooperation.id)}"> ${cooperation.cooperationName} </c:if> </c:forEach>
然而这样有个问题,好比我恰好list的值里面有一个是 15,而数据库里面存储了 1,5,那么就会显示 两个 。 这个应该是和contains有关。 只要包含他的一个子集就会所有显示。oop
而后想了想,彷佛也没有好的处理方法。又从新在后台处理了下,将逗号分隔的值放在了一个list里面,以后再jsp里面进行两个foreach 进行判断。这样就行了spa
<c:forEach var="cooperation" items="${cooperationTypeList}"> <c:forEach var="listCooperation" items="${entity.listCooperationId}"> <c:if test="${cooperation.id==listCooperation}"> ${cooperation.cooperationName} </c:if> </c:forEach> </c:forEach>