Vue表单数据修改与删除

这篇具有很好参考价值的文章主要介绍了Vue表单数据修改与删除。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

学习来源:视频p6
书接上文

数据修改功能

将之前的 BookManage 页面的按钮改为想要的功能
Vue表单数据修改与删除
可以注意到修改按钮的标签以及绑定了事件 handleClick
Vue表单数据修改与删除
点击之后其可以在控制台打印出当前行对象的内容
Vue表单数据修改与删除
观看视频时,关于修改数据,弹幕分为了两派
一派认为因该直接从页面中获取现有的数据信息加以修改,再提交给后端并存储到数据库,此流程业务简单,减轻服务器负荷。
还有一派认为因该依据关键信息或唯一标识,从后台请求这一系列数据,在此基础上进行修改,再提交给后端并存储到数据库,此流程数据安全。

我认为确实应该从后端拿数据,毕竟前端显示的数据不一定是完整信息,最全最新的内容肯定是在数据库当中,所有从后端拿数据重新修订再保存到数据库更加安全严谨。

相较于视频中新增一个页面的方式,我选择以弹出框来展示修改页面,这样我认为更切合实际场景
Vue表单数据修改与删除

修改对话框

其核心内容就是 dialogFormVisible 这个属性在点击关键字时改为 true(默认是false)
Vue表单数据修改与删除
所以运用到原来的页面上,当点击“修改”时,把这个属性置为 true 即可
Vue表单数据修改与删除

弹出的表单用原来的新增页面进行代码结合复用
将一下代码拆分放入对应位置即可

<template>
    <div>

        <el-button type="text" @click="dialogFormVisible = true">修改 Dialog</el-button>

        <el-dialog title="修改" :visible.sync="dialogFormVisible">
            <el-form style="width: 80%" :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">

                <el-form-item label="书名" prop="name">
                    <el-input v-model="ruleForm.name"></el-input>
                </el-form-item>
                <el-form-item label="作者" prop="author">
                    <el-input v-model="ruleForm.author"></el-input>
                </el-form-item>

                <el-form-item>
                    <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
                    <el-button @click="resetForm('ruleForm')">重置</el-button>
                </el-form-item>
            </el-form>

            <div slot="footer" class="dialog-footer">
                <el-button @click="dialogFormVisible = false">取 消</el-button>
                <el-button type="primary" @click="dialogFormVisible = false">确 定</el-button>
            </div>
        </el-dialog>
    </div>
</template>


<script>
    export default {
        data() {
            return {
                dialogFormVisible: false,
                formLabelWidth: '120px',
                ruleForm: {
                    name: '',
                    author: ''
                },
                rules: {
                    name: [
                        { required: true, message: '书名不能为空', trigger: 'blur' }
                    ],
                    author: [
                        { required: true, message: '作者不能为空', trigger: 'blur' }
                    ],
                }
            };
        },
        methods: {
            submitForm(formName) {
                const _this = this;
                this.$refs[formName].validate((valid) => {
                    if (valid) {
                        axios.post("http://localhost:8181/book/save",this.ruleForm).then(function (resp) {
                            if (resp.data == "success"){
                                _this.$alert("《"+_this.ruleForm.name+"》添加成功", '成功', {
                                    confirmButtonText: '确定',
                                    callback: action => {
                                        _this.$router.push("/BookMange");
                                    }
                                });
                            }else{
                                _this.$message.error("添加失败");
                            }
                        })
                    } else {
                        console.log('添加失败');
                        return false;
                    }
                });
            },
            resetForm(formName) {
                this.$refs[formName].resetFields();
            },
        }
    }
</script>

最终效果如下

Vue表单数据修改与删除

视频教程的做法

创建额外的页面,当点击修改按钮时,进行页面跳转,并用 query 传递操作的 id 信息

handleClick(row) {
    this.$router.push({
        path: '/update',
        query:{
            id: row.id
        }
    })
},

Vue表单数据修改与删除
在新的页面初始化地方进行接收参数,请求后端数据
Vue表单数据修改与删除
需要跳转用 $router ,需要接收参数用 $route

拓展阅读
route 和 router的区别
params 和 query 传递参数的区别

后端提供接口

之前 bookRepository 继承的 JPA 接口中,也已经写好了 findById() 函数,对我们来说相当方便,只是这个接口返回的对象是 Optional 的对象,其可以把空的对象也能正常包装并返回,避免出现空指针异常导致程序崩溃,Optional讲解
Vue表单数据修改与删除
再调用 get() 方法以获取到对象,结果也是能正确输出的
则下一步写入handler接口供外部调用

@GetMapping("/findById/{id}")
public Book findById(@PathVariable("id") Integer id){
    return bookRepository.findById(id).get();
}

Vue表单数据修改与删除
经测试也是可以使用的,故在前端调用

前端调用接口

当点击 修改 操作时,对调用函数 handleClick 进行修改

handleClick(row) {
    const _this = this;
    this.dialogFormVisible = true;
    axios.get("http://localhost:8181/book/findById/"+row.id).then(function (resp) {
        _this.ruleForm = resp.data;
    })
},

即可实现点击后出现弹窗+载入修改的目录信息
Vue表单数据修改与删除

修改完成后提交

将之前的立即创建改成符合业务逻辑的“修改完成”
Vue表单数据修改与删除
然后对函数 submitForm 改装一下即可
其实目前实际使用看来,不改装也能满足业务逻辑需求,JPA 的save函数自动帮我们把对象存进去了
JPA是判定了当前参数是否携带主键,如果没有就存入,如果有就修改内容

但为了业务严谨,并且以后可能遇到更复杂的业务逻辑,针对修改功能还是有必要专门开辟接口的
且根据 REST 规范,更新应该使用 PUT 请求
所以直接在 handler 里面新增接口

@PutMapping("/update")
public String update(@RequestBody Book book){
    Book result = bookRepository.save(book);
    if (result != null){
        return "success";
    }
    else {
        return "fail";
    }
}

将此处的 post 改为 put ,接口网址改成 update
Vue表单数据修改与删除

即可实现修改功能

数据删除功能

后端开设接口

@DeleteMapping("/deleteById/{id}")
public void delete(@PathVariable("id") Integer id){
    bookRepository.deleteById(id);
}

前端调用

Vue表单数据修改与删除
按钮组件绑定函数

deleteBook(row){
    const _this = this;
    axios.delete("http://localhost:8181/book/deleteById/"+row.id).then(function (resp) {
        if (resp.status == 200){
            _this.$alert("《"+row.name+"》删除成功", '成功', {
                confirmButtonText: '确定并刷新',
                callback: action => {
                    _this.$router.go(0);
                }
            });
        }else{
            _this.$message.error("删除失败");
        }
    })
},

最终成果展示

主页面js代码

<script>
    export default {
        methods: {
            handleClick(row) {
                const _this = this;
                this.dialogFormVisible = true;
                axios.get("http://localhost:8181/book/findById/"+row.id).then(function (resp) {
                    _this.ruleForm = resp.data;
                })
            },
            deleteBook(row){
                const _this = this;
                axios.delete("http://localhost:8181/book/deleteById/"+row.id).then(function (resp) {
                    if (resp.status == 200){
                        _this.$alert("《"+row.name+"》删除成功", '成功', {
                            confirmButtonText: '确定并刷新',
                            callback: action => {
                                _this.$router.go(0);
                            }
                        });
                    }else{
                        _this.$message.error("删除失败");
                    }
                })
            },
            page(currentPage){
                const _this = this;
                axios.get("http://localhost:8181/book/findPart/"+currentPage+"/3").then(function (resp) {
                    _this.tableData = resp.data.content;
                    _this.total = resp.data.totalElements;
                })
            },
            submitForm(formName) {
                const _this = this;
                this.$refs[formName].validate((valid) => {
                    if (valid) {
                        axios.put("http://localhost:8181/book/update",this.ruleForm).then(function (resp) {
                            if (resp.data == "success"){
                                _this.$alert("《"+_this.ruleForm.name+"》修改成功", '成功', {
                                    confirmButtonText: '确定',
                                    callback: action => {
                                        _this.$router.go(0);
                                    }
                                });
                            }else{
                                _this.$message.error("修改失败");
                            }
                        })
                    } else {
                        console.log('添加失败');
                        return false;
                    }
                });
            },
            resetForm(formName) {
                this.$refs[formName].resetFields();
            },
        },
        created(){
            const _this = this;
            axios.get("http://localhost:8181/book/findPart/1/3").then(function (resp) {
                _this.tableData = resp.data.content;
                _this.total = resp.data.totalElements;
            })
        },
        data() {
            return {
                total: null,
                tableData: null,
                dialogFormVisible: false,
                dialogFormVisible: false,
                formLabelWidth: '120px',
                ruleForm: {
                    name: '',
                    author: ''
                },
                rules: {
                    name: [
                        { required: true, message: '书名不能为空', trigger: 'blur' }
                    ],
                    author: [
                        { required: true, message: '作者不能为空', trigger: 'blur' }
                    ],
                }
            }
        }
    }
</script>

Vue表单数据修改与删除文章来源地址https://www.toymoban.com/news/detail-439508.html

到了这里,关于Vue表单数据修改与删除的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue2:elementUI中Form 表单在特定情况下做动态rules添加删除

    先看需求: (不想看的直接拉到最后)  【需求说明】 6、如状态为上架时,库存为必填,下架状态时,库存为可填,前面无星号 实现方法:使用this.$set()和this.$delete() 上代码: 由于设计商业隐私,代码只上传一部分:   表单data中原来的rules: 不添加上下架状态的rules 在

    2023年04月08日
    浏览(40)
  • 【vue2+element ui】添加修改共用表单的下拉框回显问题分析以及解决方案(附共用表单代码)

    简介 本人前端水平不佳,本文分享在编写个人项目前端代码的时候遇到的回显问题的解决办法,仅供参考。 问题复原 首先展示表单中的问题代码,本次前端的设计是添加和修改操作共用表单,但是其中有一个下拉框展示形式,按照惯例通过:value进行双向绑定,保证点击修改

    2024年02月07日
    浏览(44)
  • vuejs清空表单数据、删除对象中的空属性公共方法

    对于复杂数据,使用element自带的方法可能不能满足我们的需求,所以可以封装一个公共方法在全局。 一、清空表单数据: 二、删除对象中的空属性:

    2024年02月13日
    浏览(43)
  • springboot+vue2 实现文件上传,vue表单实现上传多张照片或视频回显

    此教程可以实现对上传的文件管理,并加入了我的功能需求,大家可以自行进行修改。 文件管理: 功能需求视频: 文件上传视频(图片和视频) 先来简单介绍下功能实现,实现此功能分为数据库、后端java、前端vue共同实现; 业务流程: vue页面点击上传后,通过调用后端接

    2024年02月04日
    浏览(48)
  • ruoyi-nbcio-plus基于vue3的flowable增加开始节点的表单绑定修改

    更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码: https://gitee.com/nbacheng/ruoyi-nbcio 演示地址:RuoYi-Nbcio后台管理系统 http://122.227.135.243:9666/ 更多nbcio-boot功能请看演示系统  gitee源代码地址 后端代码: https://gitee.com/nbacheng/nbcio-boot 前端代码:https://gitee.com/nbacheng/nbcio

    2024年03月23日
    浏览(45)
  • es head 新增字段、修改字段、批量修改字段、删除字段、删除数据、批量删除数据

    目录 一、新增字段 二、修改字段值 三、批量修改字段值 ​四、删除字段 五、删除数据/文档 六、批量删除数据/文档 put   http://{ip}:{port}/{index}/_mapping/{type}     其中,index是es索引、type是类型 数据: 例子: 注意:如果报错Types cannot be provided in put mapping requests, unless the in

    2024年02月04日
    浏览(54)
  • 修改经过Spring Gateway的表单中的Json数据

    使用Spring Cloud Gateway作为网关时有时候一个请求是既包含excel又包含json的表单数据,出于各种层面考虑网关需要获取并更新其中的json数据 Spring Boot版本:2.7.15 Hutool: 5.8.21 Java: 11 实现分为2个部分 使用上文提到的ModifyRequestBodyGatewayFilterFactory类来修改请求体,这样最后就不用我们

    2024年02月08日
    浏览(42)
  • ElementUI的Form表单使用slot-scope=“scope“获取当前表格行数据实现数据回显、修改表单操作

    在写项目时,老师通过向后端发请求获得表格原来的数据来填充修改表单里的数据。 这是表格: 这是点击修改按钮后显示出来的修改表单: 但本地里都已经有这些数据了,就没必要再发一次请求,徒增服务器压力。 准备 可是该怎么获得当前行的数据填充上去呢?答案在

    2023年04月23日
    浏览(48)
  • 《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能

    目录          前言          电影评价系统是什么?它能具有什么功能的体现? 一、splice方法的含义和作用 splice是什么?splice的作用体现在哪些方面?          二、功能实现 以下是实现查看逻辑功能的代码 以下是实现修改逻辑功能的代码  以下是实现删除逻辑功能的代

    2024年02月12日
    浏览(37)
  • Vue 学习随笔系列七 -- 表单动态生成

    1、动态表单组件封装 2、组件引用 3、实现效果 点击上一个选项,选中后出现下一个下拉框,并将最后一个数据回显到输入框中

    2024年02月04日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包