使用jquery动态改变checkbox选中和样式

做权限选中的时候遇到:

<div class="layui-form-item">
    <label class="layui-form-label">权限</label>
    <div class="layui-input-block">
        {foreach $menus as $k=>$v}
            <div>
                <input type="checkbox" lay-filter="checkboxs" class="checkboxs" name="roleids[]" lay-skin="primary" title="{$v['name']}" checked="" value="{$v['id']}">

                <div class="son">
                    {foreach $v['son'] as $kk=>$vv}
                        <input type="checkbox" lay-filter="checkbox" class="checkbox" name="roleids[]" lay-skin="primary" title="{$vv['name']}" checked="" value="{$vv['id']}">
                    {/foreach}
                </div>
            </div>
            <div style="height: 15px"></div>
        {/foreach}
    </div>
</div>

form.on('checkbox(checkboxs)', function(data){
    checked=data.elem.checked; //是否被选中,true或者false
    $(this).next().next().find('.checkbox').each(function (){
        $(this).prop('checked',checked)
        form.render();
    })
});

form.on('checkbox(checkbox)', function(data){
    checked=data.elem.checked; //是否被选中,true或者fals
    //判断兄弟check是否还有选中个数
    var checkednum=0
    $(this).parent('.son').find('.checkbox').each(function (){
        if($(this).prop('checked')){
            checkednum++
        }
    })
    if(checkednum>0){
        $(this).parent('.son').prev().prev().prop('checked',true)
    }else{
        $(this).parent('.son').prev().prev().prop('checked',false)
    }​​​​​​​
    form.render();
​​​​​​​});

单纯记录分享,不喜勿喷

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要改变复选框的状态,可以使用 JavaScript 中的 `checked` 属性。例如,假设我们有一个 HTML 复选框元素: ```html <input type="checkbox" id="myCheckbox"> ``` 我们可以使用以下代码来将其选中或取消选中: ```javascript // 选中复选框 document.getElementById("myCheckbox").checked = true; // 取消选中复选框 document.getElementById("myCheckbox").checked = false; ``` 如果想要切换复选框的状态,可以使用以下代码: ```javascript // 切换复选框状态 document.getElementById("myCheckbox").checked = !document.getElementById("myCheckbox").checked; ``` ### 回答2: 要改变checkbox的状态,可以通过以下步骤: 1. 获取checkbox元素:首先要找到checkbox的HTML元素,可以通过getElementById、getElementsByClassName等方法来获取,或者使用jQuery的选择器来获取。 2. 监听事件:为了能够实时监听checkbox的变化,需要给checkbox添加一个onclick事件监听器。 3. 改变状态:在事件的回调函数中,通过修改checkbox的checked属性来改变checkbox的状态。例如,如果checkbox的状态是选中的,则将其checked属性设置为false,取消选中;反之,如果checkbox的状态是未选中的,则将其checked属性设置为true,选中。 示例代码如下: HTML部分: ```html <input type="checkbox" id="myCheckbox">改变checkbox状态</input> ``` JavaScript部分: ```javascript var myCheckbox = document.getElementById("myCheckbox"); // 获取checkbox元素 myCheckbox.onclick = function() { // 添加onclick事件监听器 if (myCheckbox.checked) { // 如果checkbox选中 myCheckbox.checked = false; // 取消选中 } else { // 如果checkbox选中 myCheckbox.checked = true; // 选中 } }; ``` 以上代码实现了点击checkbox时,切换checkbox选中状态。 ### 回答3: 要改变checkbox的状态,我们可以通过以下几种方式实现。 第一种方法是使用JavaScript来操作checkbox的状态。我们可以通过getElementById()方法获取到checkbox的元素,并使用checked属性来改变它的状态。当我们将checked属性设置为true时,checkbox将被选中,而当设置为false时,checkbox将不被选中。通过在JavaScript代码中使用这种方式,我们可以根据需要来改变checkbox的状态。 第二种方法是通过HTML的属性来改变checkbox的状态。在HTML中,我们可以使用checked属性来设置checkbox的状态。当我们在checkbox的input标签中添加checked属性时,checkbox将被选中,而没有该属性时,checkbox将不被选中。通过在HTML代码中使用这种方式,我们可以直接改变checkbox的初始状态。 第三种方法是使用CSS来改变checkbox样式,从而改变其状态的外观。通过给checkbox添加不同的样式,我们可以呈现不同的状态效果,例如选中状态和未选中状态。我们可以使用CSS的伪类选择器来为checkbox设置不同的样式,并通过hover、active等状态来改变其外观。 总而言之,要改变checkbox的状态,我们可以使用JavaScript、HTML的属性或CSS来实现。通过这些方式,我们可以改变checkbox选中状态或外观,以适应不同的需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值