vue+element的表格实现批量删除功能示例代码


Posted in Javascript onAugust 17, 2018

最近写了一个批量删除功能,遇到了不少坑,特此记录一下

vue+element的表格实现批量删除功能示例代码

表格的代码如下

<el-table @row-click="handleCurrentChange" @selection-change="selsChange" ref="table" :data="pageData" stripe :default-sort="{prop: 'createAt', order: 'descending'}" @sort-change="sortChange">

如图所示,表格最前面有一个复选框

代码很简单

<el-table-column type="selection" width="65"></el-table-column>

删除按钮的代码如下:

<el-button v-show="mode == 'list'" class="small" type="warning" size="small" @click="removeBatch(sels)" :disabled="this.sels.length === 0||this.disabled">批量删除</el-button>

data的代码如下:

data() {
  return {
   pageSize: 12,
   total: 0,
   pageData: [],
   query: '',
   sort: 'createAt',
   order: 'descending',
   defaultSnap: srcFallback,
   accept: '',
   ws: null,
   sels: [],//选中显示的值
   disabled:true
  };
 }

表格中的视频数据来自于pageData,每个视频都是一个对象,对象的status属性等于waiting或者有progress属性时,此视频正在转码,或者正在准备转码,不允许删除, 批量删除就是把被选中的行添加到sels这个数组中,把数组里的每一个对象的id属性组成一个数组,发送给后端,此外,正在转码的视频不允许删除,此时按钮也是禁用状态

根据官方文档,@selection-change="selsChange"是复选框选择改变时触发的事件

在methods中添加一个方法

selsChange(sels) { 
    //被选中的行组成数组 
    this.sels = sels;
    //遍历被选中行数所组成的数组
    for(let element of this.sels){
    //如果视频正在转码或者等待转码,禁用按钮,结束方法
     if(element.status == 'waiting'||element.progress){
      this.disabled = true;
      return;
     }
       //如果没有视频正在转码或者等待转码,按钮可用
      this.disabled = false;
    }
  }

把请求发送给后端,代码如下:

removeBatch(rows){
   var ids = [];
   rows.forEach(element =>{
    ids.push(element.id)
   })
   this.$confirm('确定要删除选中的文件吗?','提示').then(() =>{
    $.post('/vod/removeBatch',{
     ids:ids
    }).then(dara =>{
     this.updateData();
    })
   }).catch(()=>{});
  }

前端已经排除正在转码的视频了,后端是否能根据前端传来的数据,直接删除视频呢?

答案是不可以,后端一样要做验证

思路是,拿到前端传来的数据后,遍历数组两次,第一次如果发现有正在转码的视频,抛出异常,不会进入第二次循环,第二次循环才根据id删除视频

代码如下

r.post('/removeBatch',async(req,res) => {
  var ids = req.body.ids;
  var files = utils.vod.get("files");
  //第一次循环,如果有正在转码的文件,就抛出异常,结束循环
  for(let id of ids){
    var transing = trans.agent.transing[id];
    if(transing){
      throw new Error('正在转码的文件无法删除');
      return;
    }
  }
  //如果没有转码的文件,进入第二次循环
  for(let id of ids){
    var files = utils.vod.get("files");
    var row = files.find({id: id}).cloneDeep().value();
    //如果没有要删除的,就结束
    if(!row) {
      res.sendStatus(200);
      return;
    }
    var dir = path.dirname(row.path);
    var name = path.basename(row.path, path.extname(row.path));
    var transDir = path.resolve(dir, name);
    //删除源文件
    if(fs.existsSync(row.path)){
      fs.removeSync(row.path);
    }
    //删除转码文件
    if(fs.existsSync(transDir)){
      fs.removeSync(transDir);
    }
    //删除json文件记录
    files.remove({id: id}).write();
  }
  res.sendStatus(200);
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
再谈javascript图片预加载技术(详细演示)
Mar 12 Javascript
利用JQuery动画制作滑动菜单项效果实现步骤及代码
Feb 07 Javascript
js弹出div并显示遮罩层
Feb 12 Javascript
javascript实现添加附件功能的方法
Nov 18 Javascript
JavaScript中日期函数的相关操作知识
Aug 03 Javascript
JS实现拖动滚动条评分的效果代码分享
Sep 29 Javascript
webpack踩坑之路图片的路径与打包
Sep 05 Javascript
Angular.js中window.onload(),$(document).ready()的写法浅析
Sep 28 Javascript
在vue项目中,使用axios跨域处理
Mar 07 Javascript
详解nuxt路由鉴权(express模板)
Nov 21 Javascript
jQuery判断自定义属性data-val用法示例
Jan 07 jQuery
layui导出所有数据的例子
Sep 10 Javascript
vue富文本框(插入文本、图片、视频)的使用及问题小结
Aug 17 #Javascript
浅析vue给不同环境配置不同打包命令
Aug 17 #Javascript
React中使用async validator进行表单验证的实例代码
Aug 17 #Javascript
JavaScript实现构造json数组的方法分析
Aug 17 #Javascript
layer弹出层父子页面事件相互调用方法
Aug 17 #Javascript
layer.open 按钮的点击事件关闭方法
Aug 17 #Javascript
layer弹出层全屏及关闭方法
Aug 17 #Javascript
You might like
PHP学习之输出字符串(echo,print,printf,print_r和var_dump)
2011/04/17 PHP
php生成缩略图填充白边(等比缩略图方案)
2013/12/25 PHP
php中关于socket的系列函数总结
2015/05/18 PHP
Linux(CentOS)下PHP扩展PDO编译安装的方法
2016/04/07 PHP
国外Lightbox v2.03.3 最新版 下载
2007/10/17 Javascript
JSON语法五大要素图文介绍
2012/12/04 Javascript
jquery ajax中使用jsonp的限制解决方法
2013/11/22 Javascript
浅谈JavaScript中的字符编码转换问题
2015/07/07 Javascript
BootStrap网页中代码显示用法详解
2016/10/21 Javascript
jquery,js简单实现类似Angular.js双向绑定
2017/01/13 Javascript
用director.js实现前端路由使用实例
2017/01/27 Javascript
基于Vue2实现的仿手机QQ单页面应用功能(接入聊天机器人 )
2017/03/30 Javascript
浅谈在Vue-cli里基于axios封装复用请求
2017/11/06 Javascript
使用微信小程序开发弹出框应用实例详解
2018/10/18 Javascript
vue实现文字横向无缝走马灯组件效果的实例代码
2019/04/09 Javascript
Python XML RPC服务器端和客户端实例
2014/11/22 Python
Python编程实现粒子群算法(PSO)详解
2017/11/13 Python
Python实现图片拼接的代码
2018/07/02 Python
Python 字符串、列表、元组的截取与切片操作示例
2019/09/17 Python
Python发起请求提示UnicodeEncodeError错误代码解决方法
2020/04/21 Python
在pycharm中debug 实时查看数据操作(交互式)
2020/06/09 Python
浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack
2020/06/23 Python
python 多线程中join()的作用
2020/10/29 Python
Jupyter Notebook 安装配置与使用详解
2021/01/06 Python
CSS3感应鼠标的背景闪烁和图片缩放动画效果
2014/05/14 HTML / CSS
欧舒丹澳洲版:L’OCCITANE
2017/07/17 全球购物
高三自我鉴定范文
2013/10/19 职场文书
村长贪污检举信
2014/04/04 职场文书
关于环保的活动方案
2014/08/25 职场文书
政风行风整改报告
2014/11/06 职场文书
2014年学校安全工作总结
2014/11/13 职场文书
起诉书范文
2015/05/20 职场文书
个人催款函范文
2015/06/23 职场文书
python使用openpyxl库读写Excel表格的方法(增删改查操作)
2021/05/02 Python
详解Python函数print用法
2021/06/18 Python
JavaScript中时间格式化新思路toLocaleString()
2021/11/07 Javascript