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.pswp.cn/news/163803.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/163803.shtml
英文地址,請注明出處:http://en.pswp.cn/news/163803.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JOSEF 漏電繼電器 LLJ-100FG φ45 50-500mA 卡軌安裝

系列型號&#xff1a; LLJ-10F(S)漏電繼電器LLJ-15F(S)漏電繼電器LLJ-16F(S)漏電繼電器 LLJ-25F(S)漏電繼電器LLJ-30F(S)漏電繼電器LLJ-32F(S)漏電繼電器 LLJ-60F(S)漏電繼電器LLJ-63F(S)漏電繼電器LLJ-80F(S)漏電繼電器 LLJ-100F(S)漏電繼電器LLJ-120F(S)漏電繼電器LLJ-125F(S…

推薦一個簡單的在線壓縮PNG和JPG圖片大小的網址

問題描述&#xff1a;推薦一個簡單的在線壓縮PNG和JPG圖片大小的網址 解決&#xff1a; https://www.iloveimg.com/zh-cn/compress-image/compress-png

將對象轉成URL參數

背景 有的時候前端跳轉到其他平臺的頁面需要攜帶額外的參數&#xff0c;需要將對象轉成用 & 連接的字符串拼接在路徑后面。 實現方法

C++中對SQLite進行增刪改查

#include <iostream> #include <sqlite3.h>// 創建數據庫連接 sqlite3* OpenDatabase(const char* dbFilePath) {sqlite3* db;// 打開數據庫if (sqlite3_open(dbFilePath, &db) ! SQLITE_OK) {std::cerr << "Error opening database." <<…

HTTP ERROR 403 No valid crumb was included in the request

1、報錯截圖&#xff1a; 2、產生原因&#xff1a; 開啟了csrf&#xff0c;即跨站請求偽造 3、新版本不支持頁面修改&#xff0c;故需要修改jenkins配置文件 3.1 進入編輯配置文件 vim /etc/sysconfig/jenkins 3.2 修改JENKINS_JAVA_OPTIONS&#xff0c;并保存修改 JENKI…

深度學習之四(循環神經網絡Recurrent Neural Networks,RNNs)

概念 循環神經網絡(Recurrent Neural Networks,RNNs)是一類專門用于處理序列數據的神經網絡,它在處理時考慮了序列數據的順序和上下文信息。RNNs 在自然語言處理、時間序列分析、語音識別等領域得到廣泛應用。 1. 基本結構: RNN 的基本結構包含一個或多個循環單元,每個…

Ubuntu 系統上使用 QQ 郵箱的 SMTP 服務器發送郵件,msmtp(已驗證)

安裝 msmtp sudo apt-get update sudo apt-get install msmtp2 .配置 msmtp nano ~/.msmtprcdefaults auth on tls on tls_starttls on tls_trust_file /etc/ssl/certs/ca-certificates.crt logfile ~/.msmtp.logaccount qq host …

Lua腳本解決redis實現的分布式鎖多條命令原子性問題

線程1現在持有鎖之后&#xff0c;在執行業務邏輯過程中&#xff0c;他正準備刪除鎖&#xff0c;而且已經走到了條件判斷的過程中&#xff0c;比如他已經拿到了當前這把鎖確實是屬于他自己的&#xff0c;正準備刪除鎖&#xff0c;但是此時他的鎖到期了&#xff0c;那么此時線程2…

Android : ExpandableListView(折疊列表) +BaseExpandableListAdapter-簡單應用

示例圖&#xff1a; 實體類DemoData.java package com.example.myexpandablelistview.entity;public class DemoData {private String content;private int img;public DemoData(String content, int img) {this.content content;this.img img;}public String getContent()…

STM32——外部中斷

文章目錄 0.中斷關系映射1.使能 IO 口時鐘&#xff0c;初始化 IO 口為輸入2.設置 IO 口模式&#xff0c;觸發條件&#xff0c;開啟 SYSCFG 時鐘&#xff0c;設置 IO 口與中斷線的映射關系。3.配置NVIC優先級管理&#xff0c;并使能中斷4.編寫中斷服務函數。5.編寫中斷處理回調函…

springboot多數據源集成

springboot多數據源集成 1、添加依賴2、添加配置3、代碼使用4、動態切換數據庫 1、添加依賴 <!--多數據源--> <dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version…

[個人筆記] Windows的IT運維筆記

IT技術 - 運維篇 第二章 Windows的IT運維筆記 IT技術 - 運維篇系列文章回顧一、Windows10專業版添加gpedit.msc二、海康威視前端頁面導出通道名稱參考鏈接 系列文章回顧 第一章 快速下載微軟評估版本鏡像的方法 一、Windows10專業版添加gpedit.msc 執行以下bat腳本 echo off…

Rust使用iced構建UI時,如何在界面顯示中文字符

注&#xff1a;此文適合于對rust有一些了解的朋友 iced是一個跨平臺的GUI庫&#xff0c;用于為rust語言程序構建UI界面。 iced的基本邏輯是&#xff1a; UI交互產生消息message&#xff0c;message傳遞給后臺的update&#xff0c;在這個函數中編寫邏輯&#xff0c;然后通過…

護法革命:CIMIVO+SOTUY洗前發膜讓發絲重獲“芯”生

愛美之心人皆有之,經常燙染或者是在太陽下暴曬,都會對發絲造成一定的傷害,一旦發絲受損,就會導致發芯內部角蛋白流失、化學鍵連接斷裂,進而出現各種發質問題。為此,日本知名化妝品集團NABOCUL旗下發芯修護引領品牌ENNEO創新研發兩大核心成分:CIMIVO、SOTUY,能夠從根源修護發芯內…

EXCEL小技巧

1、兩列文本合并顯示&#xff1a; CONCATENATE(B6,E6) &#xff08;如果顯示公式而非文本&#xff0c;就是公式輸錯了&#xff0c;比如后缺少空格&#xff09;

mac 終端配置

Mac iTerm2 配置 安裝 brew install iTerm2安裝完成之后&#xff0c;需要重新打開終端&#xff0c;既可以看見安裝 iTerm2 的效果。 iTerm2 美化 使用 oh-my-zsh 美化 iTerm2 終端 安裝 brew install wget sh -c "$(wget https://raw.github.com/ohmyzsh/ohmyzsh/mast…

宇宙工具箱:辦公娛樂兩不誤堪稱手機的百寶箱

宇宙工具箱 宇宙工具箱&#xff0c;提供大量實用工具&#xff0c;多種類型盡在其中&#xff0c;支持圖片/視頻處理、計算、查詢、娛樂等多方內容&#xff0c;滿足用戶使用需求&#xff0c;超多工具直接使用。 獲取資源 詳細獲取地址請點擊 宇宙工具箱 功能特點 1、計算工具…

【硬核HeyGen平替】在window平臺上使用MyHeyGen

最近在研究HeyGen的平替開源項目&#xff0c;然后發現了MyHeyGen這個項目&#xff0c;但是文檔上面并沒有說明如果在window平臺上使用&#xff0c;考慮到非window平臺安裝顯卡驅動什么的比較繁瑣&#xff0c;所以嘗試硬著頭皮干... 前提 開源項目中所需的環境準備要先準備好 1…

測試15k薪資第1步 —— 自動化測試理論基礎

目錄 1、自動化測試定義 2、自動化測試分類&工具 3、未來發展趨勢 1.1、什么是自動化測試 自動化測試指的是利用軟件工具或腳本來執行測試任務&#xff0c;以替代手動測試過程的一種測試方法。它的主要目的是通過自動化執行、驗證和評估軟件應用的功能、穩定性、性能等方面…

Kotlin(十一) 標準函數with、run和apply

with with函數接收兩個參數&#xff1a;第一個參數可以是一個任意類型的對象&#xff0c;第二個參數是一個Lambda表達式。with函數會在Lambda表達式中提供第一個參數對象的上下文&#xff0c;并使用Lambda表達式中的最后一行代碼作為返回值返回。示例代碼如下&#xff1a; va…