当前位置: 首页 > news >正文

Vue + Element UI 实现复制当前行数据功能(复制到新增页面组件值不能更新等问题解决)

1、需求

使用Vue + Element UI 实现在列表的操作栏新增一个复制按钮,复制当前行的数据可以打开新增弹窗后亦可以跳转到新增页面,本文实现为跳转到新增页面。

2、实现

1)列表页 index.vue

<el-table>
<!-- 其他列 -->
<el-table-column label="操作" width="150"><template slot-scope="scope"><el-button icon="el-icon-copy-document" title="复制"  @click="toCopyNew(scope.row)"></el-button></template></el-table-column>
</el-table>

方法部分:用id来区分,正常新增id为0,复制id不为0

methods: {// 复制toCopyNew (item) {const { url } = this.$getKey('这是是业务权限值,不需要这里可以不写')this.$router.push(`/${url}-New/${item.Id}`)},
}

2)新增页 New.vue

data () {return {id: this.$route.params.id,dataList: [],form: {Name: '',BG: '',InfoJson: [],},rules: {Name: [{ required: true, message: '请输入名称', trigger: 'blur' },],BG: [{ required: true, message: '请选择所属组织', trigger: 'change' },],InfoJson: [{ required: true, message: '请选择集合', trigger: 'blur' },],},submitLoading: false,}},created () {if (this.id !== '0') {this._getDetail()}},methods: {async _getDetail () {try {// 获取详情接口const data = await GetInfo({Id: this.id * 1,})if (data) {this.form = datathis.form.id = ''this.form.Name = data.Namethis.form.BG= { Id: data.BG_Id, Name: data.BG_Name }this.form.InfoJson= JSON.parse(data.InfoJson)this.dataList = this.form.InfoJson}} catch (error) {}},}

3)问题

按上述代码操作后,点击列表操作栏的复制按钮会跳转到新增页面并且将当前行的数据复制到对应各个组件内,数据呈现和保存正常,但是发现了一个问题,数据无法修改,网上查阅资料应该异步获取详情信息且数据获取时打印输出下返回数据是否有问题等,具体分析如下

① 异步问题

确保数据的获取是异步完成的。如果你的数据是通过异步请求获取的,确保在数据返回之前不要执行任何赋值操作。你可以使用async/await或者.then()语法确保异步请求完成后再进行赋值。

② 数据是否正确

确保你查询到的数据是正确的。你可以在控制台打印查询到的数据,确保它包含你所需的信息。

③ Reactivity(响应性)

Vue.js中的响应性是通过数据属性的getter和setter来实现的。确保你正在使用Vue.js的响应性系统来更新数据。如果你是在异步操作中修改数据,确保在Vue.js的上下文中执行这些操作。

④ 组件是否正确渲染

确保组件已正确渲染,并且你正在尝试更改的数据在组件中可见。你可以在组件的模板中使用双花括号 {{ variable }} 来输出数据,以确保它们正在正确显示。

4)解决

经过排查,本文问题为周期和响应性问题,具体修改为调整周日created为mounted,调整数据返回的赋值方式改为响应式获取,思路和代码如下:

① 之前在 created 钩子中异步调用方法,可能会导致在数据获取之前组件渲染完成,这可能导致数据无法正确地绑定到组件。将数据获取移动到 mounted 钩子中,因为 mounted 钩子在组件已经挂载到 DOM 后触发,这时候可以确保组件已经渲染完成。
② Vue.js 需要对象是响应式的才能在数据更改时触发视图更新。确保你的 form 对象是在 data 中声明的,并且使用了 Vue.set 或 this.$set 来确保嵌套属性的响应性。
mounted () {if (this.id !== '0') {this._getDetail()}},methods: {async _getDetail () {try {// 获取详情接口const data = await GetInfo({Id: this.id * 1,})if (data) {this.form = datathis.form.id = ''// 使用 Vue.set 或 this.$set 来确保响应性this.$set(this.form, 'Name', data.RG_Name)this.$set(this.form, 'Sign', data.RG_Sign)this.$set(this.form, 'BG', { Id: data.BG_Id, Name: data.BG_Name })this.$set(this.form, 'Sign', data.RG_Sign)this.$set(this.form, 'RuleJson', JSON.parse(data.RuleJson))this.dataList = this.form.RuleJson}} catch (error) {}},}

5)其他方便排查的原因在此做个列举

① 确保数据绑定正确

在模板中使用双花括号 {{ variable }} 输出数据,确保数据正确地绑定到组件。例如,你可以在模板中添加一些输出语句:

<template><div>{{ form.Name }}{{ form.BG }}<!-- 其他组件的输出语句 --></div>
</template>

这将帮助你确定是否有数据正确地传递到了组件

② 检查数据类型和结构

确保 GetInfo 返回的数据与你在 New.vue 中的期望一致。可以在 mounted 钩子中使用 console.log(data) 来查看获取的数据结构。

async _getDetail () {try {const data = await GetInfo({Id: this.id * 1,})console.log(data); // 查看数据结构// ... 其他代码} catch (error) {}
}

③ 检查是否有报错信息

查看浏览器控制台是否有任何错误消息。可能有网络请求问题或其他导致数据无法正确加载的问题。

④ 确保组件的 form 数据对象是响应式的

Vue.js 需要对象是响应式的才能在数据更改时触发视图更新。确保你的 form 对象是在 data 中声明的,并且使用了 Vue.set 或 this.$set 来确保嵌套属性的响应性。如本文解决办法

若本文有帮助到阅读本文的同学,欢迎点赞、关注、收藏,互相学习交流。

http://www.lryc.cn/news/242246.html

相关文章:

  • 嵌入式FPGA IP正在发现更广阔的用武之地
  • [点云分割] 条件欧氏聚类分割
  • Spring事务粒度优化与传播机制
  • MySQL 基于成本的优化
  • 【maven】【IDEA】idea中使用maven编译项目,报错java: 错误: 找不到符号 【2】
  • AIGC,ChatGPT AI绘画 Midjourney 注册流程详细步骤
  • 万字解析设计模式之模板方法与解释器模式
  • apipost接口200状态码,浏览器控制台500状态码
  • Instant Web API .Net Core Crack
  • vue项目使用easyplayer播放m3u8直播推流
  • Python报错:AttributeError(类属性、实例属性)
  • vue+springboot读取git的markdown文件并展示
  • 多功能PHP图床源码:Lsky Pro开源版v2.1 – 最新兰空图床
  • Hive内置表生成函数
  • 电源控制系统架构(PCSA)之电源控制框架概览
  • Sentinel 监控数据持久化(mysql)
  • 基于法医调查算法优化概率神经网络PNN的分类预测 - 附代码
  • canvas高级动画001:文字瀑布流
  • 抽象类, 接口, Object类 ---java
  • SOAP 协议和 HTTP 协议:深入解读与对比
  • Unity发布IOS后,使用xcode打包报错:MapFileParser.sh:Permissiondenied
  • 2021年12月 Scratch(三级)真题解析#中国电子学会#全国青少年软件编程等级考试
  • mac上Homebrew的安装与使用
  • YOLOv5 分类模型 预处理 OpenCV实现
  • 在arm 64 环境下使用halcon算法
  • H5(uniapp)中使用echarts
  • QLineEdit设置掩码Ip
  • 开源语音大语言模型来了!阿里基于Qwen-Chat提出Qwen-Audio!
  • 缓存雪崩、击穿、穿透及解决方案_保证缓存和数据库一致性
  • 仿 美图 / 饿了么,店铺详情页功能