<c:forEach items="${rolelist}" var="rl" varStatus="status">
<input type="checkbox" id="rolename" value="${rl.roleid}" name="rolename"
<c:forEach items="${userrole}" var="ul" varStatus="status">
<c:if test="${ul.roleid==rl.roleid}">
checked="checked"
</c:if>
</c:forEach>
>
${rl.rolename}
</c:forEach>
上面的截图是最终的效果图。这次开发的任务是做权限管理,那么一个用户可能有多个角色,大概思路是:在后端我先把所有的角色名称取出来为rolelist,接着根据用户id取出用户角色表(userrole该表属性有userid和roleid)中对应的list集合为userrole,然后在前端利用jstl循环遍历并勾选对应的角色,当userrole.roleid==rolelist.roleid时勾选
后端相关代码如下:
String sql2="SELECT * FROM t_roles";//得到角色列表
List<Map<String,Object>> rolelist=DBUtil.getObjects(sql2, null);
model.addAttribute("rolelist", rolelist);
String sql3="SELECT * FROM t_userroles WHERE n_userid="+id;//得到该用户拥有的roleid可能有多个roleid
List<Map<String,Object>> userrole=DBUtil.getObjects(sql3, null);
model.addAttribute("userrole", userrole);
之前踩到的坑是没把以下代码放进<input type="checkbox" id="rolename" value="${rl.roleid}" name="rolename" >里面,要接在name="rolename" 后面写,希望大家在开发的时候不要踩到这个坑
<c:forEach items="${userrole}" var="ul" varStatus="status">
<c:if test="${ul.roleid==rl.roleid}">
checked="checked"
</c:if>
</c:forEach>