checkbox多选框级联勾选(父类被都选之后相应的子类也被勾选)

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
response.flushBuffer();%>
<%@ include file="/util/taglib.jsp" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" >
<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gbk">
<script type="text/javascript">
//级联勾选函数
function getchecks() {
var parentCategorys = document.getElementsByName("parentchk");
for (var k=0; k<parentCategorys.length; k++){
var test = parentCategorys[k];
if (test.checked) {
var id = test.id;
var childs = document.getElementsByName("chk");
var a = 0;
for (var i=0; i<childs.length; i++){
var child = childs[i];
var parentid = child.id;
//alert(id==parentid);
if (id==parentid) {
child.checked = true;
}
}
}else{
continue;
}
}
}

</script>
<title>人群关联度</title>
</head>
<body>
<div class="page">
<div class="pageHeader">
</div>
<div class="pageContent">
<form method="post" id="addre" action="${pageContext.request.contextPath }/exactrelated.do?action=categoryRes&flag=save" class="pageForm required-validate" onsubmit="return validateCallback(this);">
<input type="hidden" name="categoryId" value="${categoryId }"/>
<div class="pageFormContent" layoutH="56" width="60">
<!-- 父类循环,父类被勾选的时候下面的子类都相应的被勾选上 -->
<c:forEach items="${parentCategoryList}" var="m">

<c:if test="${m.pid == 0}">
<p>
<c:choose>
<c:when test="${m.flag==0}">
<label><input type="checkbox" id="${m.categoryId }" name="parentchk" value="${m.categoryId }" checked onclick="getchecks()"/>  <font style="color:red">${m.categoryName }</font></label>
</c:when>

<c:otherwise>
<label><input type="checkbox" id="${m.categoryId }" name="parentchk" value="${m.categoryId }" onclick="getchecks()" />  <font style="color:red">${m.categoryName }</font></label>
</c:otherwise>
</c:choose>
</p>
</c:if>
<!-- 子类循环 -->
<c:forEach items="${categoryList}" var="l">
<c:if test="${m.categoryId == l.pid}">
<p>
<c:choose>
<c:when test="${l.flag==0}">
<label><input type="checkbox" flag="${m.categoryId }" id="${l.pid}" name="chk" value="${l.categoryId }" checked/>  ${l.categoryName }</label>
</c:when>

<c:otherwise>
<label><input type="checkbox" flag="${m.categoryId }" id="${l.pid }" name="chk" value="${l.categoryId }" />  ${l.categoryName }</label>
</c:otherwise>
</c:choose>
</p>
</c:if>
</c:forEach>

<div class="divider"></div>
</c:forEach>

</div>
<div class="formBar">
<ul>
<li><div class="buttonActive"><div class="buttonContent"><button type="submit">保存</button></div></div></li>
<li>
<div class="button"><div class="buttonContent"><button type="Button" onclick="navTab.closeCurrentTab()">取消</button></div></div>
</li>
</ul>
</div>
</form>
</div>
</div>
</body>
</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值