Vue form表單動態(tài)添加組件實戰(zhàn)案例
今天我們來給大家介紹下在Vue開發(fā)中我們經(jīng)常會碰到的一種需求場景,就是在form中我們需要動態(tài)的增加組件模塊,效果如下:

這種效果實現(xiàn)其實就是對 v-for 指令的一種使用,組件不是必須的,只是為了將這部門的代碼我們單獨(dú)的拎出來,便于查看,好了,話不多說,我們來看下具體怎么來實現(xiàn)。
案例效果的實現(xiàn)
1.創(chuàng)建組件
首先我們創(chuàng)建一個單獨(dú)的組件,同時在 template 中定義我們的表單元素,此處使用的是 element UI 來實現(xiàn)效果。

2.import組件
我們需要在父組件中引入創(chuàng)建的組件,并通過 v-for 來實現(xiàn)動態(tài)處理的效果,關(guān)鍵代碼如下

使用組件

在 data 中定義 edus 數(shù)組.

3.實現(xiàn)添加功能
要實現(xiàn)動態(tài)添加組件的功能,我們需要通過點(diǎn)擊添加的按鈕來增加數(shù)組 edus 中的元素,如下

let addEduView = function(){
this.edus.push({})
}
如此即可實現(xiàn)動態(tài)添加的功能。
4.實現(xiàn)移除功能
實現(xiàn)移除動態(tài)添加的組件,我們需要在組件中調(diào)用父組件中的方法。如下
父組件中定義移除的方法
let deleteEducation = function(index){
if (index !== 0) {
this.edus.splice(index, 1)
}
}

子組件中回調(diào)

5.提交數(shù)據(jù)
當(dāng)我們要提交表單數(shù)據(jù)的時候,怎么將動態(tài)添加的組件中的數(shù)據(jù)一并提交給后臺服務(wù)呢,步驟如下:


提交數(shù)據(jù)的時候?qū)?edus 數(shù)組中的數(shù)據(jù)和表單數(shù)據(jù)一塊轉(zhuǎn)換為 JSON 數(shù)據(jù)提交到后臺。

6.清空組件
最后操作完成需要將動態(tài)添加的組件處理掉怎么實現(xiàn)呢?其實效果很簡單,我們只需要清空 edus 數(shù)組即可

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解windows下vue-cli及webpack 構(gòu)建網(wǎng)站(三)使用組件
本篇文章主要介紹了詳解windows下vue-cli及webpack 構(gòu)建網(wǎng)站(三)使用組件,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
Vue3使用video-player實現(xiàn)視頻播放
video-player是一個基于video.js的視頻播放器組件,本文主要介紹了Vue3使用video-player實現(xiàn)視頻播放,具有一定的參考價值,感興趣的可以了解一下2024-01-01
vue改變對象或數(shù)組時的刷新機(jī)制的方法總結(jié)
這篇文章主要介紹了vue改變對象或數(shù)組時的刷新機(jī)制的方法總結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04
Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題)
本文主要介紹了Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
vue如何在for循環(huán)中設(shè)置ref并獲取$refs
眾所周知在寫循環(huán)的時候給循環(huán)中的數(shù)據(jù)定義ref以便再下面直接通過this.$ref.來訪問,下面這篇文章主要給大家介紹了關(guān)于vue如何在for循環(huán)中設(shè)置ref并獲取$refs的相關(guān)資料,需要的朋友可以參考下2022-12-12

