Vue2+ElementUI的el-table实现新增数据行与删除的功能

Vue2+ElementUI的el-table实现新增数据行与删除的功能

文章目录

  • Vue2+ElementUI的el-table实现新增数据行与删除的功能
  • 1. 代码
  • 2. 效果

1. 代码

TableIndex.vue如下

<template><div><div><el-button @click="add" class="filter-item" plain type="primary">新增</el-button><el-button @click="batchDelete" class="filter-item" plain type="danger">删除</el-button></div><el-table :data="tableData.records" :key="tableKey" size="small"@selection-change="onSelectChange"border fit row-key="id" ref="table" style="width: 100%;" v-loading="loading"><el-table-column align="center" type="selection" width="40px" column-key="selectionId":reserve-selection="true"/><el-table-column v-if="false"><template slot-scope="scope"><el-input v-model="scope.row.id"></el-input></template></el-table-column><el-table-column label="标题"align="center" prop="blockTitle"width="300px"><template slot-scope="scope"><el-input v-model="scope.row.blockTitle"></el-input></template></el-table-column><el-table-column label="类型"align="center" prop="blockType"width="120px"><template slot-scope="scope"><el-select v-model="scope.row.blockType"><el-option label="表单" value="0"/><el-option label="表格" value="1"/><el-option label="树表" value="2"/><el-option label="甘特图" value="3"/></el-select></template></el-table-column><el-table-column label="数据源" :show-overflow-tooltip="true"align="center" prop="blockUrl"width=""><template slot-scope="scope"><el-input v-model="scope.row.blockUrl"></el-input></template></el-table-column><el-table-column label="是否有效"align="center" prop="izValidate"width="150px"><template slot-scope="scope"><el-radio v-model="scope.row.izValidate" label="1" default></el-radio><el-radio v-model="scope.row.izValidate" label="0"></el-radio></template></el-table-column><el-table-column:label="$t('table.operation')" align="center" column-key="operation"class-name="small-padding fixed-width"width="100px"><template slot-scope="{ row }"><i @click="singleDelete(row)" class="el-icon-delete table-operation" title="删除" style="color: #f50;"/></template></el-table-column></el-table></div>
</template><script>
import elDragDialog from '@/directive/el-drag-dialog'
import {v4 as uuidv4} from 'uuid';export default {name: "TableIndex",directives: {elDragDialog},filters: {},data() {return {selections: [],tableData: {records: [],total: 0},tableKey: 0,loading: false,};},computed: {},watch: {},mounted() {},methods: {add() {// 添加新行this.tableData.records.push({id: uuidv4(), blockTitle: '', blockType: '', blockUrl: '', izValidate: '1'});},// 单行删除方法singleDelete(row) {console.log(row)this.tableRowsDelete(new Array(row.id))},//批量删除方法batchDelete() {if (!this.selections.length) {this.$message({message: "请先选择需要删除的数据",type: "warning"});return;}//获取要删除的记录idconst delIds = this.selections.map(row => row.id);this.tableRowsDelete(delIds)},// 删除表格数据行的方(用于单行及批量删除按钮操作)tableRowsDelete(delIds) {this.$confirm('此操作将永久删除, 是否继续?', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {//根据id删除this.tableData.records = this.tableData.records.filter(item => !delIds.includes(item.id));this.$refs.table.clearSelection();this.$message({type: 'success',message: '删除成功!'});}).catch(() => {this.clearSelections();this.$message({type: 'info',message: '已取消删除'});});},//当选择项发生变化时会触发该事件onSelectChange(selection) {this.selections = selection;},//清空表格选择clearSelections() {this.$refs.table.clearSelection();}}
};
</script>
<style lang="scss" scoped></style>

2. 效果

  1. 新增按钮添加数据行

在这里插入图片描述

  1. 删除按钮提示是否继续删除

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/118.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

通过ABAP程序自动创建信息对象-第二弹

前言 上一篇讲了通过ABAP程序去自动生成BW的ADSO模型&#xff0c;这一篇讲讲信息对象的自动生成&#xff0c; 一、实现效果 对于BW顾问来说&#xff0c;模型建完之后&#xff0c;就要开始选择用字段还是用信息对象进行建模&#xff0c;如果信息对象不存在呢&#xff0c;那么…

SpringBoot整合Activiti7——实战之放假流程(会签)

文章目录 代码实现部署流程启动流程填写放假通知任务投票审批xml文件 会签场景&#xff1a; 开始 - 填写放假通知单&#xff08;代理人&#xff09;- 投票审批&#xff08;指定多个参与人&#xff09;- 根据设置的完成条件后&#xff0c;全部参与人必须完成后&#xff0c;自动结…

小米su7全力提高产能,小米su7的这几个问题你都知道吗?车载随身wifi哪款最好用?公认最好的随身wifi格行随身wifi怎么样?

小米汽车官方近日回应网友关切&#xff0c;透露小米SU7非创始版交付进度。工厂正处于生产爬坡阶段&#xff0c;正全力提升产能和物料准备节奏&#xff0c;以加快交付效率。对于锁单后能否调整提车时间&#xff0c;小米汽车表示将与销售沟通协商。 当然关于网友们的问题也进行了…

条码的基础知识

条码的基础知识 条码&#xff1a;条码是由一组按一定编码规则排列的条、空符号组成&#xff0c;用以表示一定的字符、数字及符号组成的信息 一维码 Code 128 Code 128 是一种密度很高的字母数字代码系统&#xff0c;可对其进行双向扫描。此代码系统可编码整个 128 ASCII 字…

ERROR in [eslint] reorder to top import/first

情景再现&#xff1a;在react开发的时候&#xff0c;导入组件、函数时报错&#xff1a;Import in body of module; reorder to top import/first … 原因&#xff1a;在import语句前有变量声明 解决&#xff1a; 变量的声明&#xff0c;要放在import之后 // 错误示例 import {…

物联网网络传输,STM32和ESP32

2024.4.17 今天主要是记录一下我这个STM32F407和esp8266组成的互联网板子的一些例程运行心得&#xff0c; 下面这个例程是STM32发AT指令给esp8266&#xff0c;使得esp8266作为tcp client连接到我的手机热点&#xff0c;然后我用电脑连接wifi&#xff0c;打开tcp server&#x…

【CDN产品测评-笔记】探索云服务中的安全和性能增强功能

【CDN产品测评-笔记】探索云服务中的安全和性能增强功能 写在最前面1. DNS管理&#xff1a;核心的域名服务功能2. DDoS防护&#xff1a;构筑坚不可摧的防线3. Web防护&#xff1a;智能化的网络攻击防御4. BOT管理&#xff1a;精准识别与流量控制5. 加速服务&#xff1a;提升全球…

【动态规划 区间dp 位运算】3117. 划分数组得到最小的值之和

本文涉及知识点 动态规划 区间dp 位运算 LeetCode3117. 划分数组得到最小的值之和 给你两个数组 nums 和 andValues&#xff0c;长度分别为 n 和 m。 数组的 值 等于该数组的 最后一个 元素。 你需要将 nums 划分为 m 个 不相交的连续 子数组&#xff0c;对于第 ith 个子数组…

各RAID级别的特点以及对应的容量计算方式

RAID&#xff08;Redundant Array of Independent Disks&#xff09;是一种将多个独立的硬盘组合起来以提高数据存储性能、容量或冗余度的技术。在实际项目中&#xff0c;通常采购的磁盘阵列支持设置对应的RAID级别。本人也进行过实战&#xff0c;而现在为了应对软考来总结一下…

【攻防世界】lottery

弱比较代码审计 本题已提供源码&#xff0c;如果没提供&#xff0c;输入/robots.txt&#xff0c;发现/.git function buy($req){require_registered();require_min_money(2);$money $_SESSION[money];//接受用户原有money$numbers $req[numbers];//接受输入的数字$win_num…

C++类和对象第二弹(构造,析构和拷贝构造函数)

目录 前言 1. 类的6个默认成员函数 2. 构造函数 2.1 概念 2.2 特性 3. 析构函数 3.1 概念 3.2 特性 4. 拷贝构造函数 4.1 概念 4.2 特征 总结 前言 本文主要讲解类中构造函数、析构函数和拷贝构造函数。关于这三个类中默认成员函数的知识点很多&#xff0c;有许多…

视觉SLAM学习打卡【10】-后端·滑动窗口法位姿图

本节是对上一节BA的进一步简化&#xff0c;旨在提高优化实时性.难点在于位姿图部分的雅可比矩阵求解&#xff08;涉及李代数扰动模型求导&#xff09;&#xff0c;书中的相关推导存在跳步&#xff08;可能数学功底强的人认为过渡的理所当然&#xff09;&#xff0c;笔者参考了知…

【Gradle】Gradle的构建过程

Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化构建开源工具。它使用一种基于Groovy的特定领域语言(DSL)来声明项目设置&#xff0c;也增加了基于Kotlin语言的kotlin-based DSL&#xff0c;抛弃了基于XML的各种繁琐配置。 面向Java应用为主。当前其支持的语言C、J…

免费网址导航网站源码v1.7.0最新版内置多个模板

效果图 PC端&移动端&#xff08;共有7款主题&#xff09; 1.5IUX搜索 2.Onenav主题 六零二开 3.基于彩虹工具网修改 4.默认主题 5.基于default主题开发 6.极简个人主页主题 7.孤客主题 后台管理效果图 项目说明 孤客导航页&#xff08;LoSFeR&#xff09;是一个…

Zephyr Windows开发环境搭建

Zephyr 如果有错误或未及时更新&#xff0c;请以官网文档为主 官网&#xff1a;https://docs.zephyrproject.org/latest/develop/getting_started/index.htm 下载安装 Chocolatey 这是一个类似于在Linux系统下 yum 和 apt 那样的包管理器 官网&#xff1a;https://chocolat…

安宝特方案 | AR工业解决方案系列-工厂督查

在工业4.0时代&#xff0c;增强现实&#xff08;AR&#xff09;技术正全面重塑传统工业生产&#xff0c;在工厂监督领域&#xff0c;其应用不仅大幅提升了生产效率、监测准确性和规范执行程度&#xff0c;而且为整体生产力带来了质的飞跃。 01 传统挑战与痛点 在制造业生产流程…

未来趋势:探索Facebook在数字化时代的发展方向

在当今日益数字化的时代&#xff0c;社交媒体已经成为人们日常生活中不可或缺的一部分。Facebook&#xff0c;作为全球最大的社交媒体平台&#xff0c;一直处于行业的前沿&#xff0c;不断地探索和引领社交媒体的发展趋势。本文将深入探讨Facebook在数字化时代的发展方向&#…

如何解决Charles抓包乱码?

一、问题&#xff1a;抓包乱码 二、 1、打开Charles安装的目录下&#xff0c;Charles.ini文件&#xff0c; 2、添加内容、保存 vmarg.5-Dfile.encodingUTF-8 三、重启&#xff0c;再次抓包

Object.assign()用法及详细分析到底是浅拷贝还是深拷贝?

Object.assign方法用于对象的合并&#xff0c;将源对象&#xff08;source &#xff09;的所有可枚举属性&#xff0c;复制到目标对象&#xff08;target&#xff09;。 Object.assign(target,source1,source2) Object.assign方法的第一个参数是目标对象&#xff0c;后面的参数…

Next.js动态路由如何使用

官方解释 Next.js 允许你创建具有 动态路由 的页面。例如&#xff0c;你可以创建一个名为 pages/posts/[id].js 的文件用以展示以 id 标识的单篇博客文章。当你访问 posts/1 路径时将展示 id: 1 的博客文章。 代码 这里先用一个写好的实例代码来展示 import React from react…