Vue复选框批量删除示例

Vue复选框批量删除

通过使用v-model指令绑定单个复选框

例如<input type="checkbox" id="checkbox" v-model="checked">

而本次我们要做的示例大致是这样的,首先可以增加内容,然后通过勾选来进行单独或者批量删除 ,但是在此处就可以进行批量操作。

通过勾选原神和明日进行批量删除后,发现成功了,那么这就是表名咱们的操作没有问题,接下来就要具体代码实现。

具体代码实现

body中div,挂载点是zjw,也就是张俊伟的缩写,当然这可以自己写什么都行,只要与Vue里面的el对应

html 复制代码
<div id="zjw">
<span>添加一条内容</span>
<input placeholder="输入内容" v-model="value"/>
<button @click="add()">添加</button>
  <ul>
    <li v-for="(item,index) in list" :key="index">
        <input type="checkbox" v-model="item.c"/>
        <span>{{item.d}}</span>
        <button @click="remove(index)">删除</button></li>
  </ul>
    <button @click="removeAll()">批量删除</button>
</div>
<script>
  const app=new Vue({
    el:'#zjw',
    data(){
      return{
        list:[{d:'洗碗',c:false},{d:'擦地',c:false}],
        value:''
      }
    },
    methods:{
      add(){
          adds={
              d:this.value,
              c:false
          }
        this.list.push(adds)
        this.value=''
      },
      remove(i){
          if(this.list[i].c==true)
        this.list.splice(i,1)
      },
        removeAll(){
            for (var i = this.list.length - 1; i >= 0; i--)
                if (this.list[i].c==true) this.list.splice(i, 1);
        }
    }
  })
</script>

分析环节

添加的框

添加操作用@click绑定了一个add()
在input中的v-model是value

html 复制代码
<span>添加一条内容</span>
<input placeholder="输入内容" v-model="value"/>
<button @click="add()">添加</button>

下面是script内容
在data中我是用了对象数组来做,里面用了一个c来放复选的状态false没选,true选

而add中也是每次添加的不止文字,还有false或者true,通过this.list.push(adds)加入到数组队尾

html 复制代码
data(){
      return{
        list:[{d:'洗碗',c:false},{d:'擦地',c:false}],
        value:''
      }
    },
    methods:{
      add(){
          adds={
              d:this.value,
              c:false
          }
        this.list.push(adds)
        this.value=''
      },

对于单个删除和批量操作

这里通过<li v-for="(item,index) in list" :key="index"> <input type="checkbox" v-model="item.c"/> <span>{``{item.d}}</span> <button @click="remove(index)">删除</button></li>

来讲data中的数据显示出来,并且可以删除或者批量

button中,使用v-model="item.c"绑定复选框的状态

html 复制代码
 <ul>
    <li v-for="(item,index) in list" :key="index">
        <input type="checkbox" v-model="item.c"/>
        <span>{{item.d}}</span>
        <button @click="remove(index)">删除</button></li>
  </ul>
    <button @click="removeAll()">批量删除</button>

单个删除就是如下操作,一个简单判断this.list[i].c的值就行

对于多选其实也就是多了一个在数组中的循环
for (var i = this.list.length - 1; i >= 0; i--)就可以完成批量删除了

html 复制代码
  remove(i){
          if(this.list[i].c==true)
        this.list.splice(i,1)
      },
        removeAll(){
            for (var i = this.list.length - 1; i >= 0; i--)
                if (this.list[i].c==true) this.list.splice(i, 1);
        }
相关推荐
Younglina14 小时前
一个纯前端的网站集合管理工具
前端·vue.js·chrome
木头程序员14 小时前
前端(包含HTML/JavaScript/DOM/BOM/jQuery)基础-暴力复习篇
开发语言·前端·javascript·ecmascript·es6·jquery·html5
卖火箭的小男孩14 小时前
# Flutter Provider 状态管理完全指南
前端
小雨青年14 小时前
鸿蒙 HarmonyOS 6|ArkUI(01):从框架认知到项目骨架
前端
Null15514 小时前
浏览器唤起本地桌面应用(基础版)
前端·浏览器
哈__14 小时前
React Native 鸿蒙跨平台开发:PixelRatio 实现鸿蒙端图片的高清显示
javascript·react native·react.js
wszy180915 小时前
外部链接跳转:从 App 打开浏览器的正确姿势
java·javascript·react native·react.js·harmonyos
pas13615 小时前
31-mini-vue 更新element的children
前端·javascript·vue.js
wordbaby15 小时前
TanStack Router 实战:如何构建经典的“左侧菜单 + 右侧内容”后台布局
前端·react.js
oMcLin15 小时前
如何在 RHEL 7 上优化 Nginx 与 PHP‑FPM 配置,确保高并发 Web 应用的稳定性与响应速度?
前端·nginx·php