判断checkBox为空,左右删除选项值

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<script type="text/javascript">
        <!--
         var bCount=1;
         //插入行
         function addOp(id,name){
            newRow=hadchoice.insertRow(hadchoice.rows.length);
            newRow.id="trhad";
            newRow.ln=bCount;
         
            Del=newRow.insertCell(0);
            Del.ln=bCount;
            Del.οnclick=delOp;
            Del.innerHTML="<input type='checkbox' name='hadcho' style='width:40' value='"+id+"'  ln='"+bCount+"' checked>"+name;
              
            bCount++;
         }
         //删除行
         function delOp(){
              line=parseInt(event.srcElement.ln,10);
              var disSelected;
              if (line>0) {
                   for (i=1;i<hadchoice.rows.length;i++){
                    if (trhad[i].ln==line){
                        disSelected=event.srcElement.value;//获得删除值
                         hadchoice.deleteRow(i)
                    }
                   }
               }
            var operator = document.getElementsByName("operator");
            for(i=0;i<operator.length;i++) {
                if(operator[i].value==disSelected) {
                    operator[i].checked=false;
                }
            }

              
         }
         //判断左边的行在右边是否已经存在
         function justValue(chbox,id, name) {
            var hadvalue=false;//是否已经选择
            var exits = document.getElementsByName("hadcho");
            if(exits.length!=0){
                for(i=0;i<exits.length;i++) {
                    if(exits[i].value==id) {
                        if(chbox.checked==true) {//如果是已选,则添加
                            exits[i].checked=true;
                            hadvalue=true;
                        } else if(chbox.checked==false) {//如果是未选,则删除行
                            hadvalue=true;
                            var line=parseInt(exits[i].ln,10);
                            if (line>0) {
                                for (j=1;j<hadchoice.rows.length;j++){
                                    if (trhad[j].ln==line){
                                        hadchoice.deleteRow(j);
                                    }
                                }
                            }
                        }
                    }
                }
            }
            if(!hadvalue) {//未选择,则添加行
                addOp(id,name);
            }
         }
         </script>
</HEAD>

<BODY>
    <form name="frm" action="" method="post">
    <table>
        <tr>
            <td>
                <table>
                    <tr>
                        <td><input type="checkbox" name="operator" οnclick="justValue(this,'1','一');" value="1">一</td>
                    </tr>
                    <tr>
                        <td><input type="checkbox" name="operator" οnclick="justValue(this,'2','二');" value="2">二</td>
                    </tr>
                    <tr>
                        <td><input type="checkbox" name="operator" οnclick="justValue(this,'3','三');" value="3">三</td>
                    </tr>
                    <tr>
                        <td><input type="checkbox" name="operator" οnclick="justValue(this,'4','四');" value="4">四</td>
                    </tr>
                    <tr>
                        <td><input type="checkbox" name="operator" οnclick="justValue(this,'5','五');" value="5">五</td>
                    </tr>
                </table>
   
            </td>
            <td>
                <table id="hadchoice">
                    <tr id="trhad">
                        <td></td>
                    </tr>
                </table>
            </td>
        </tr>
    </table>
    </form>
</BODY>
</HTML>

在Uniapp中,我们可以通过以下方法实现checkbox选中往数组添加,取消从数组删除的功能。 首先,我们需要在数据中定义一个数组,用于存储选中的checkbox。例如,我们可以定义一个data中的属性selectedItems,其初始为空数组。 然后,在checkbox的绑定事件中,我们可以通过判断checkbox的选中状态来执行不同的操作。当checkbox选中时,我们可以将其添加到selectedItems数组中;当checkbox取消选中时,我们可以通过数组的indexOf方法找到该在selectedItems中的索引,并使用splice方法将其从数组中删除。 具体实现如下: ```vue <template> <view> <checkbox-group @change="checkboxChange"> <checkbox value="item1" />选项1 <checkbox value="item2" />选项2 <checkbox value="item3" />选项3 </checkbox-group> </view> </template> <script> export default { data() { return { selectedItems: [] // 存储选中的checkbox的数组 }; }, methods: { checkboxChange(event) { const value = event.mp.detail.value; // 获取checkbox选中的 // 判断当前checkbox是否已经选中 const index = this.selectedItems.indexOf(value); if (index === -1) { // 不存在于数组中,说明是新选中的checkbox this.selectedItems.push(value); // 将其添加到数组中 } else { // 存在于数组中,说明是取消选中的checkbox this.selectedItems.splice(index, 1); // 从数组中删除 } } } }; </script> ``` 通过以上代码,我们就可以实现当checkbox选中时往数组中添加其,取消选中时从数组中删除的功能。注意,这里的实现方式只是一种方法,你可以根据具体的需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值