詳解Vue里循環(huán)form表單項(xiàng)實(shí)例
有的時(shí)候我們可能會(huì)遇到這種需求,用戶點(diǎn)擊某個(gè)按鈕就可以增加一個(gè)同樣的表單出來(lái),點(diǎn)擊一次增加一次。然后要用到深拷貝,Vue.js+ElementUI等等。效果大概如下,就是一個(gè)表單有下拉框和兩個(gè)輸入框,現(xiàn)在點(diǎn)擊"添加表單"按鈕之后就會(huì)多一個(gè)表單出來(lái),點(diǎn)擊"提交表單"后就同時(shí)提交兩個(gè)表單的value值。
代碼如下:
<template> <div> <div style="margin: 10px 0"> <el-button type="primary" @click="addForm">添加表單</el-button> <el-button type="primary" @click="submit">提交表單</el-button> </div> <div v-for="(item, index) in List" :key="index"> <el-form ref="form" label-width="80px"> <el-form-item label="直播平臺(tái)"> <el-select v-model="item.platform" :key="index" placeholder="請(qǐng)選擇直播平臺(tái)" > <el-option :label="item2.platformName" v-for="(item2, index2) in platformNameList" :key="index2" :value="item2.platformValue" > </el-option> </el-select> </el-form-item> <el-form-item label="粉絲量"> <el-input v-model="item.fanMount" :key="index"></el-input> </el-form-item> <el-form-item label="平臺(tái)ID"> <el-input v-model="item.platformId" :key="index"></el-input> </el-form-item> </el-form> </div> </div> </template> <script> export default { data() { return { title: "巡查內(nèi)容頁(yè)", personObj: { platform: "", fanMount: "", platformId: "", }, platformNameList: [ { platformName: "快手", platformValue: "1", }, { platformName: "抖音", platformValue: "2", }, { platformName: "淘寶", platformValue: "3", }, ], List: [ { platform: "", fanMount: "", platformId: "", }, ], }; }, methods: { //深拷貝 cloneObj(obj) { let ret; if (Array.isArray(obj)) { //創(chuàng)建一個(gè)空數(shù)組 ret = []; for (let i = 0; i < obj.length; i++) { ret[i] = this.cloneObj(obj[i]); } return ret; } else if (Object.prototype.toString.call(obj) === "[object Object]") { ret = {}; for (let i in obj) { ret[i] = this.cloneObj(obj[i]); } return ret; } else { return obj; } }, //添加表單 addForm() { let arr = this.cloneObj(this.personObj); console.log("arr", arr); this.List.push(arr); }, //提交表單 submit() { console.log("this.List", this.List); }, }, }; </script>
代碼分析:
這里封裝了一個(gè)深拷貝函數(shù),每次點(diǎn)擊添加表單時(shí)就會(huì)拷貝一份我們定義好的對(duì)象,注意這個(gè)對(duì)象是由我們初始表單的value值組合起來(lái)的,我們?cè)谧钔鈱佑胿-for遍歷數(shù)組List然后每次點(diǎn)擊"添加表單"就往數(shù)組里push一個(gè)對(duì)象,最后點(diǎn)擊"提交表單"按鈕,打印this.List就能看到整個(gè)的數(shù)組對(duì)象了,我們來(lái)試一下,選擇輸入以下值:
控制臺(tái)打印看下效果:
現(xiàn)在假如說有個(gè)需求是,指定添加幾項(xiàng)表單,而不是點(diǎn)一次加一次表單,效果如下,有三個(gè)按鈕,最開始顯示一個(gè)表單
當(dāng)我點(diǎn)擊"3個(gè)"按鈕的時(shí)候,界面總共有三個(gè)表單,如下圖:
代碼如下:
<template> <div> <div style="margin: 10px 0"> <el-button type="primary" @click="add(3)">3個(gè)</el-button> <el-button type="primary" @click="addForm">添加表單</el-button> <el-button type="primary" @click="submit">提交表單</el-button> </div> <div v-for="(item, index) in List" :key="index"> <el-form ref="form" label-width="80px"> <el-form-item label="直播平臺(tái)"> <el-select v-model="item.platform" :key="index" placeholder="請(qǐng)選擇直播平臺(tái)" > <el-option :label="item2.platformName" v-for="(item2, index2) in platformNameList" :key="index2" :value="item2.platformValue" > </el-option> </el-select> </el-form-item> <el-form-item label="粉絲量"> <el-input v-model="item.fanMount" :key="index"></el-input> </el-form-item> <el-form-item label="平臺(tái)ID"> <el-input v-model="item.platformId" :key="index"></el-input> </el-form-item> </el-form> </div> </div> </template> <script> export default { data() { return { title: "巡查內(nèi)容頁(yè)", personObj: { platform: "", fanMount: "", platformId: "", }, platformNameList: [ { platformName: "快手", platformValue: "1", }, { platformName: "抖音", platformValue: "2", }, { platformName: "淘寶", platformValue: "3", }, ], List: [ { platform: "", fanMount: "", platformId: "", }, ], }; }, methods: { cloneObj(obj) { let ret; if (Array.isArray(obj)) { //創(chuàng)建一個(gè)空數(shù)組 ret = []; for (let i = 0; i < obj.length; i++) { ret[i] = this.cloneObj(obj[i]); } return ret; } else if (Object.prototype.toString.call(obj) === "[object Object]") { ret = {}; for (let i in obj) { ret[i] = this.cloneObj(obj[i]); } return ret; } else { return obj; } }, add(a) { this.addForm(a); }, addForm(a) { let arr = this.cloneObj(this.personObj); console.log("arr", arr); this.List.push(arr); a--; if (a > 0) { this.addForm(a - 1); } }, submit() { console.log("this.list", this.List); }, }, }; </script> <style> </style>
代碼分析如下:
點(diǎn)擊按鈕的add方法的時(shí)候傳入總共的表單個(gè)數(shù),然后在添加表單的方法addForm里用了自減和判斷、遞歸來(lái)實(shí)現(xiàn)連續(xù)點(diǎn)擊時(shí)的拷貝等。然后我們?cè)囈幌滦Ч?br />
控制臺(tái)打印看一下
到此這篇關(guān)于詳解Vue里循環(huán)form表單項(xiàng)實(shí)例的文章就介紹到這了,更多相關(guān)Vue循環(huán)form表單項(xiàng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式
這篇文章主要介紹了vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Vue按時(shí)間段查詢數(shù)據(jù)組件使用詳解
這篇文章主要為大家詳細(xì)介紹了Vue按時(shí)間段查詢數(shù)據(jù)組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08VueJs中如何使用Teleport及組件嵌套層次結(jié)構(gòu)詳解
這篇文章主要為大家介紹了VueJs中如何使用Teleport及組件嵌套層次結(jié)構(gòu)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04vue3.2自定義彈窗組件結(jié)合函數(shù)式調(diào)用示例詳解
這篇文章主要為大家介紹了vue3.2自定義彈窗組件結(jié)合函數(shù)式調(diào)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09基于Vue2.0+ElementUI實(shí)現(xiàn)表格翻頁(yè)功能
Element UI 是一套采用 Vue 2.0 作為基礎(chǔ)框架實(shí)現(xiàn)的組件庫(kù),它面向企業(yè)級(jí)的后臺(tái)應(yīng)用,能夠幫助你快速地搭建網(wǎng)站,極大地減少研發(fā)的人力與時(shí)間成本。這篇文章主要介紹了Vue2.0+ElementUI實(shí)現(xiàn)表格翻頁(yè)功能,需要的朋友可以參考下2017-10-10