求javascript checkbox 选中事件代码

5个新闻大项分类,假设ID为bigclassauthorize;每个大项中有3个新闻小项分类,假设ID为smallclassauthorize;我想要代码是在控制编辑状态... 5个新闻大项分类,假设ID为bigclassauthorize;每个大项中有3个新闻小项分类,假设ID为smallclassauthorize;
我想要代码是在控制编辑状态下:
如果先点击大项A中的bigclassauthorize为true的话,其3个小项可为true可为false;
如果先点击大项A中的bigclassauthorize为false的话,其3个小项全为false;
只要任何小项为true的话,大项A的bigclassauthorize为true;
如果先点击3个小项的smallclassauthorize都为false的话,大项A的bigclassauthorize为false;
不满足以上条件的话,ALERT“错误”~~
分一定给大人们~~请帮忙 很急~~
因为俺是初学者,所以才不会写嘛嘻嘻 ~~“tz6060996”的答案很接近了,但是我试过了你的代码,结果点第二个大项里面的小项后,第一个大项的bigclassauthorize也为True了,俺是动态的,所以只是列了一个大项和一个小项出来的~~也就是说我的大项和小项都只有一个ID而已,麻烦再改改嘛“tz6060996”
展开
 我来答
王路飞爱学习
高粉答主

2018-12-06 · 分享热爱,用心创作~
王路飞爱学习
采纳数:132 获赞数:110426

向TA提问 私信TA
展开全部

首先通过getElementById或其它方式获得这些对象obj,然后判断obj.checked = true或false就可以了。

例:

<input id='bigclassauthorize' type='checkbox' onclick='testClickBigCheckBox()'/>

<input id='smallclassauthorize1' type='checkbox'/>

<input id='smallclassauthorize2' type='checkbox'/>

....

function testClickBigCheckBox(){

var big = document.getElementById('bigclassauthorize');

var small1 = document.getElementById('smallclassauthorize1');

var small2 = document.getElementById('smallclassauthorize2');

if(big.checked == true){

small1.checked = true;

small2.checked = true;

}else{

small1.checked = false;

small2.checked = false;

}

}

代码可以精简或者封装,这里只是简单的描述一下基本做法,以上是大项被选中的事件处理,小项的原理差不多。

扩展资料:

思路:获取checkbox对象,根据value属性设置checkbox的checked属性(true为选中,false为取消选中)。下面实例演示——根据文本框的制定值设置复选框的选中项:

1、HTML结构

<input name="test" type="checkbox" value="1" />item-1

<input name="test" type="checkbox" value="2" />item-2

<input name="test" type="checkbox" value="3" />item-3<br>

<input name="test" type="checkbox" value="4" />item-4

<input name="test" type="checkbox" value="5" />item-5<br>

<input type="text" id="val"><input type="button" value="确定" onclick="fun()">

2、javascript代码

function fun(){

var val = document.getElementById("val").value.split(",");

var boxes = document.getElementsByName("test");

for(i=0;i<boxes.length;i++){

for(j=0;j<val.length;j++){

if(boxes[i].value == val[j]){

boxes[i].checked = true;

break

}

}

}

}

tz6060996
2009-08-12 · TA获得超过2283个赞
知道大有可为答主
回答量:1171
采纳率:100%
帮助的人:1624万
展开全部
<style type="text/css">
.aaa
{
border: 1px hidden #0000FF;
width: 100px;
height: 60px;
background-color: #cccccc;
}
</style>
<input name="bigclassauthorize" id="bigclassauthorize" type="checkbox" onclick="bigChange(this)"/>大类
<div class="aaa">
<input name="smallclassauthorize" type="checkbox" onclick="smallChange(this)" value="小类一"/>小类一<br />
<input name="smallclassauthorize" type="checkbox" onclick="smallChange(this)" value="小类二"/>小类二<br />
<input name="smallclassauthorize" type="checkbox" onclick="smallChange(this)" value="小类三"/>小类三
</div>

<script language="javascript" type="text/javascript">
function bigChange(obj) {
if (obj.checked == false) {
var smObj = document.getElementsByName("smallclassauthorize");
for (var i = 0; i < smObj.length; i++)
smObj[i].checked = false;
}
}
function smallChange(obj) {
var smObj = document.getElementsByName("smallclassauthorize");
var bigObj = document.getElementById("bigclassauthorize");
if (obj.checked == true)
bigObj.checked = true;
else {
b = true;
for (var i = 0; i < smObj.length; i++) {
if (smObj[i].checked == true)
b = false;
}
if (b == true)
bigObj.checked = false;

}
}
</script>
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
heruyi
2009-08-14 · TA获得超过558个赞
知道小有建树答主
回答量:197
采纳率:0%
帮助的人:177万
展开全部
首先你通过getElementById或其它方式获得这些对象obj,然后判断obj.checked = true或false就可以了.
例:
<input id='bigclassauthorize' type='checkbox' onclick='testClickBigCheckBox()'/>
<input id='smallclassauthorize1' type='checkbox'/>
<input id='smallclassauthorize2' type='checkbox'/>
....

function testClickBigCheckBox(){
var big = document.getElementById('bigclassauthorize');
var small1 = document.getElementById('smallclassauthorize1');
var small2 = document.getElementById('smallclassauthorize2');
if(big.checked == true){
small1.checked = true;
small2.checked = true;
}else{
small1.checked = false;
small2.checked = false;
}
}
代码可以精简或者封装,这里只是简单的描述一下基本做法.
以上是大项被选中的事件处理.
小项的原理差不多,判断稍微多一点.慢慢写锻炼自己动手操作能力.

- -//, 都一样, 动态的话完全不能这么写 .
得用循环判断. 这里只能给你思路 .
另外想知道这样的效果,去网上搜js treeview .写的好的菜单很多的.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
熊熊佳谨Ra
2009-08-11
知道答主
回答量:71
采纳率:0%
帮助的人:0
展开全部
留个脚印 我也想看看怎么做的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式