vue 表格数据增加修改(vue element实现表格增加删除修改数据)
类别:编程学习 浏览量:636
时间:2022-03-30 00:33:38 vue 表格数据增加修改
vue element实现表格增加删除修改数据本文实例为大家分享了vue element实现表格增加删除修改数据的具体代码,供大家参考,具体内容如下
这里用到是设置一个弹出框来实现此功能,还有一种方法是直接在原来的基础上面进行修改
效果如下:
表格的table:
<el-table :data="tableData" style="width: 100%"> <el-table-column prop="date" label="日期" width="180"></el-table-column> <el-table-column prop="name" label="姓名" width="180"></el-table-column> <el-table-column prop="address" label="地址"></el-table-column> <el-table-column label="操作"> <template slot-scope="scope"> <!-- 点击编辑进入编辑页面进行编辑表格数据 --> <el-button size="small" @click="handleEdit(scope.$index, scope.row)">编辑</el-button> <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)">删除</el-button> </template> </el-table-column> </el-table>
弹出框的设置:
<!-- 下面这个用来设置点击添加按钮的弹出框,里面可以进行嵌套表格来展示弹出的表格信息,使用下面的:visible.sync来控制显示与否 --> <!-- 里面绑定的是我们新设置的值,填写完成后,将我们这个新值塞到页面中所有的数据当中去 --> <el-dialog title="用户信息" :visible.sync="dialogFormVisible"> <!-- 在el-dialog中进行嵌套el-form实现弹出表格的效果 --> <el-form :model="form"> <el-form-item label="地址" :label-width="formLabelWidth"> <el-input v-model="form.address" auto-complete="off"></el-input> </el-form-item> <el-form-item label="姓名" :label-width="formLabelWidth"> <el-input v-model="form.name" auto-complete="off"></el-input> </el-form-item> <el-form-item label="日期" :label-width="formLabelWidth"> <el-date-picker v-model="form.date" type="date" placeholder="选择日期" value-format="yyyy-MM-dd" ></el-date-picker> </el-form-item> <el-form-item label="性别" :label-width="formLabelWidth"> <el-select v-model="form.region" placeholder="性别"> <el-option label="男" value="男"></el-option> <el-option label="女" value="女"></el-option> </el-select> </el-form-item> </el-form> <li slot="footer" class="dialog-footer"> <el-button @click="cancel">取 消</el-button> <!-- 设置触发更新的方法 --> <el-button type="primary" @click="update">确 定</el-button> </li> </el-dialog>
完整的代码如下:
<template> <li class="basetable" v-loading="loading" element-loading-text="拼命加载中"> <!-- v-loading 设置加载 --> <li class="selectMenu"> <el-date-picker v-model="value6" type="daterange" placeholder="选择日期范围"></el-date-picker> <!-- 点击触发add方法 --> <el-button type="primary" @click="add">新增</el-button> </li> <li class="tableMain"> <el-table :data="tableData" style="width: 100%"> <el-table-column prop="date" label="日期" width="180"></el-table-column> <el-table-column prop="name" label="姓名" width="180"></el-table-column> <el-table-column prop="address" label="地址"></el-table-column> <el-table-column label="操作"> <template slot-scope="scope"> <!-- 点击编辑进入编辑页面进行编辑表格数据 --> <el-button size="small" @click="handleEdit(scope.$index, scope.row)">编辑</el-button> <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)">删除</el-button> </template> </el-table-column> </el-table> </li> <li class="page"> <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page.sync="currentPage3" :page-size="100" layout="prev, pager, next, jumper" :total="1000" ></el-pagination> </li> <!-- 下面这个用来设置点击添加按钮的弹出框,里面可以进行嵌套表格来展示弹出的表格信息,使用下面的:visible.sync来控制显示与否 --> <!-- 里面绑定的是我们新设置的值,填写完成后,将我们这个新值塞到页面中所有的数据当中去 --> <el-dialog title="用户信息" :visible.sync="dialogFormVisible"> <!-- 在el-dialog中进行嵌套el-form实现弹出表格的效果 --> <el-form :model="form"> <el-form-item label="地址" :label-width="formLabelWidth"> <el-input v-model="form.address" auto-complete="off"></el-input> </el-form-item> <el-form-item label="姓名" :label-width="formLabelWidth"> <el-input v-model="form.name" auto-complete="off"></el-input> </el-form-item> <el-form-item label="日期" :label-width="formLabelWidth"> <el-date-picker v-model="form.date" type="date" placeholder="选择日期" value-format="yyyy-MM-dd" ></el-date-picker> </el-form-item> <el-form-item label="性别" :label-width="formLabelWidth"> <el-select v-model="form.region" placeholder="性别"> <el-option label="男" value="男"></el-option> <el-option label="女" value="女"></el-option> </el-select> </el-form-item> </el-form> <li slot="footer" class="dialog-footer"> <el-button @click="cancel">取 消</el-button> <!-- 设置触发更新的方法 --> <el-button type="primary" @click="update">确 定</el-button> </li> </el-dialog> </li> </template> <script type="text/ecmascript-6"> export default { data() { return { loading: true, // 表格的数据 tableData: [ { date: "2017-05-01", name: "士兵76", region: "男", address: "国王大道", city: "" }, { date: "2017-05-02", name: "源氏", region: "男", address: "尼泊尔", city: "" }, { date: "2017-05-03", name: "黑百合", region: "女", address: "沃斯卡亚工业区", city: "" }, { date: "2017-05-04", name: "猎空", region: "女", address: "国王大道", city: "" }, { date: "2017-05-03", name: "查莉娅", region: "女", address: "沃斯卡亚工业区", city: "" }, { date: "2017-05-03", name: "禅雅塔", region: "男", address: "尼泊尔", city: "" }, { date: "2017-05-03", name: "半藏", region: "女", address: "花村", city: "" } ], // 城市选择数据 cityList: [ { name: "国王大道" }, { name: "尼泊尔" }, { name: "沃斯卡亚工业区" }, { name: "花村" }, { name: "尼泊尔" }, { name: "月球基地" } ], dialogFormVisible: false, formLabelWidth: "80px", // 设置form用于进行添加的时候绑定值 form: {}, value6: "", currentPage3: 1, currentIndex: "" }; }, created() { // 设置回调函数,进行1.5秒的loading动画显示 setTimeout(() => { this.loading = false; }, 1500); }, methods: { showTime() { this.$alert(this.value6, "起止时间", { confirmButtonText: "确定", callback: action => { this.$message({ type: "info", message: "已显示" }); } }); }, // 增加数据的方式,单独的设置一些值,用于增加功能,这些值放在对象里面进行设置,然后将这个新增的对象塞到总数据里面 add() { this.form = { date: "", name: "", region: "", address: "" }; // 设置点击按钮之后进行显示对话框 this.dialogFormVisible = true; }, update() { // this.form.date = reformat(this.form.date); // 可以在html上面进行设置日期的格式化 // 将我们添加的信息提交到总数据里面 this.tableData.push(this.form); this.dialogFormVisible = false; }, handleEdit(index, row) { // 将数据的index传递过来用于实现数据的回显 this.form = this.tableData[index]; this.currentIndex = index; // 设置对话框的可见 this.dialogFormVisible = true; }, handleDelete(index, row) { // 设置类似于console类型的功能 this.$confirm("永久删除该文件, 是否继续?", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning" }) .then(() => { // 移除对应索引位置的数据,可以对row进行设置向后台请求删除数据 this.tableData.splice(index, 1); this.$message({ type: "success", message: "删除成功!" }); }) .catch(() => { this.$message({ type: "info", message: "已取消删除" }); }); }, cancel() { // 取消的时候直接设置对话框不可见即可 this.dialogFormVisible = false; }, handleSizeChange(val) { console.log(`每页 ${val} 条`); }, handleCurrentChange(val) { console.log(`当前页: ${val}`); } } }; </script> <style lang="scss"> .basetable { .tableMain { margin: { top: 10px; } } .page { float: left; margin: { top: 10px; } } } </style>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
您可能感兴趣
- vue中怎么触发复选框的点击事件(vue点击弹窗自动触发点击事件的解决办法模拟场景)
- google 调试vue(Vue实现Google第三方登录的示例代码)
- vue怎么配置到idea(idea编译器vue缩进报错问题场景分析)
- vue项目有element插件(Vue Element前端应用开发之前端API接口的封装)
- vue-websocket 组件教程(Vue+express+Socket实现聊天功能)
- vue实现树形结构菜单(vue递归实现三级菜单)
- vuecli项目入门(vue-cli4.5.x快速搭建项目)
- vue找不到水印设置(Vue使用自定义指令实现页面底部加水印)
- 使用vue独立开发组件(vue单文件组件的实现)
- vueelementui组件生成页面(Vue Element前端应用开发之树列表组件)
- vue左右滑动切换(vue实现界面滑动效果)
- vue 单文件组件(vue实现一个单文件组件的完整过程记录)
- vue通过什么获取dom(vue异步更新dom的实现浅析)
- vue中如何判断请求状态码(关于VUE的编译作用域及slot作用域插槽问题)
- vue组件滚动加载教程(Vue组件封装上传图片和视频的示例代码)
- vuejs指令解析(Vue.js中的计算属性、监视属性与生命周期详解)
- 包水饺(包水饺手法怎么包视频)
- 越南河粉(越南河粉来自哪里)
- 按这几方面养护佛肚竹盆景,保证枝叶繁茂,造型优美(按这几方面养护佛肚竹盆景)
- 冰岛旅游攻略(冰岛旅游攻略及花费八日游)
- 寒假旅游攻略(成都寒假旅游攻略)
- 菲律宾旅游攻略(菲律宾旅游攻略地图)
热门推荐
- sqlserver登录身份验证(SQL Server 2012 身份验证Authentication)
- sqlserver配置管理器不见了(SQL Server配置管理器无法连接到WMI提供程序)
- pythonindex函数用法(python sort、sort_index方法代码实例)
- 香港服务器有哪些优势呢(浅谈香港服务器与香港云主机的区别)
- 欧洲云服务器和VPS有哪些区别?(欧洲云服务器和VPS有哪些区别?)
- html5中的语义化标签有哪些(详解HTML5常用的语义化标签)
- mysqlreplace用法(细说mysql replace into用法)
- svg怎么在html中显示(html svg生成环形进度条的实现方法)
- vue 为什么使用虚拟dom(Vue虚拟Dom到真实Dom的转换)
- 云服务器怎么设置端口映射(云服务器怎么修改远程端口)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9