vue+js多选删除li

//全选
<van-button type="primary" size="small" @click="delMuch">删除</van-button>
//列表
<li v-for="(item, index) in titles" :key="index">
    <van-swipe-cell>
      <p
        style="
          display: flex;
          justify-content: space-between;
          align-items: center;
        "
      >
        <span
          style="
            display: flex;
            justify-content: flex-end;
            align-items: center;
          "
        >
          <input
            type="checkbox"
            :value="item.id"
            v-model="selectArr"
          />
          <span @click="clickLi(item)">{{ item.name }}</span>
        </span>
      </p>
      <template slot="right">
        <van-button
          type="primarAy"
          size="normal"
          @click="deleteList(item)"
          >删除</van-button
        >
      </template>
    </van-swipe-cell>
</li>
data() {
  return {
    titles:[]
    selectArr: [],
},
methods:{
  //多选
  calculatAll(event) {
    var _this = this;
    console.log(event.currentTarget);
    if (!event.currentTarget.checked) {
      this.selectArr = [];
    } else {
      //实现全选
      _this.selectArr = [];
      _this.titles.forEach(function (item, i) {
        _this.selectArr.push(item.fileId);
      });
      console.log(_this.selectArr);
    }
  },
  // 多选删除
  delMuch() {
    this.Dialog.confirm({
      message: "确定删除吗?",
    })
      .then(() => {
         let arr = [];
         var len = this.titles.length;
         for (var i = 0; i < len; i++) {
           var fileId = this.titles[i].fileId;
           if (this.selectArr.indexOf(fileId) >= 0) {
             // this.selectArr.indexOf(i),
             console.log("i", this.selectArr.indexOf(fileId));
           } else {
             arr.push(this.titles[i]);
           }
         }
         this.titles = arr;
         this.selectArr = [];
      })
      .catch((res) => {
        this.Toast("未知错误");
      });
  },
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值