vue +element 删除按钮操作 (删除单个数据 +删除页码处理 )

1.配置接口deleteItemById: "/api/goods/deleteItemById", //删除商品操作

2.get请求接口

复制代码
//   删除接口  后台给我们 返id
    deleteItemById(params){
        return axios.get(base.deleteItemById,{params})
    }

3.异步请求接口

复制代码
async deleteItemById(id){
        let res = await this.$api.deleteItemById({id})
        console.log('删除',res.data);
        }

4.删除完数据,表格数据也要跟着变动主要是这行代码 this.deleteItemById(row,id) 在删除事件里边操作

复制代码
      handleDelete(index, row) {
        console.log('删除操作---',index, row);
         this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning'
        }).then(() => {
             this.deleteItemById(row,id)
        }).catch(() => {
          this.$message({
            type: 'info',
            message: '已取消删除'
          });          
        });
      },

5.删除完数据 下边的分页也要处理 在分页事件里边 把val取出来

复制代码
//   分页  因为val是局部变量 在data初始化一个变量 给val传递过去
      CurrentChange(val){
        console.log('分页传过来的',val);
        this.current = val//把this.Current给删除的重新渲染页
        this.projectList(val)
      },

6.传递完了给删除接口拿到页,重新把数据渲染到表格里边

复制代码
// 删除接口
    async deleteItemById(id){
        let res = await this.$api.deleteItemById({id})
        console.log('删除',res.data);
        if(res.data.status===200){
               this.$message({
                type: 'success',
                message: '删除成功!'
            });
            this.projectList(this.current)
        }
    }

7.数据删除了;假如如果当前是最后一页的最后一条数据 删除后 获取上一页的数据 判断 this.total总数目

复制代码
  // 如果当前是最后一页的最后一条数据 删除后 获取上一页的数据  判断 this.total总数目
            if(this.total%this.pageSize === 1){
                this.curent = this.curent -1 > 0? this.current:1;//最好>1
            }

全部代码

复制代码
 <el-button size="mini" @click="handleDelete(scope.$index, scope.row)"  type="danger" icon="el-icon-delete">删除</el-button>

删除接口(里边涉及到 删除事件+分页+和重新渲染)

复制代码
 // 删除接口
    async deleteItemById(id){
        let res = await this.$api.deleteItemById({id})
        console.log('删除',res.data);
        if(res.data.status===200){
               this.$message({
                type: 'success',
                message: '删除成功!'
            });
            // 删除完之后会重新渲染页面
            // 如果当前是最后一页的最后一条数据 删除后 获取上一页的数据  判断 this.total总数目
            if(this.total%this.pageSize === 1){
                this.curent = this.curent -1 > 0? this.current:1;//最好>1
            }
            this.projectList(this.current)
        }
    }

删除事件

复制代码
   handleDelete(index, row) {
        console.log('删除操作---',index, row);
         this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning'
        }).then(() => {
             this.deleteItemById(row,id)
        }).catch(() => {
          this.$message({
            type: 'info',
            message: '已取消删除'
          });          
        });
      },

在删除第3页面数据 的时候,想在第3页看表格数据

复制代码
 //   分页  因为val是局部变量 在data初始化一个变量 给val传递过去
      CurrentChange(val){
        console.log('分页传过来的',val);
        this.current = val//把this.Current给删除的重新渲染页
        this.projectList(val)
      },

data里边初始化

复制代码
current =1
相关推荐
weixin_437830948 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
超级无敌攻城狮8 小时前
3 分钟学会!波浪文字动画超详细教程,从 0 到 1 实现「思考中 / 加载中」高级效果
前端
excel9 小时前
用 TensorFlow.js Node 实现猫图像识别(教学版逐步分解)
前端
前端工作日常9 小时前
我学习到的Vue2.6的prop修饰符
vue.js
gnip9 小时前
JavaScript事件流
前端·javascript
小菜全10 小时前
基于若依框架Vue+TS导出PDF文件的方法
javascript·vue.js·前端框架·json
赵得C10 小时前
【前端技巧】Element Table 列标题如何优雅添加 Tooltip 提示?
前端·elementui·vue·table组件
wow_DG10 小时前
【Vue2 ✨】Vue2 入门之旅 · 进阶篇(一):响应式原理
前端·javascript·vue.js
weixin_4569042710 小时前
UserManagement.vue和Profile.vue详细解释
前端·javascript·vue.js
资深前端之路10 小时前
react 面试题 react 有什么特点?
前端·react.js·面试·前端框架