又接到新需求了吧~~
背景
在一個(gè)大表單里,有可能會(huì)出現(xiàn)這種需求,用戶可以自己操作動(dòng)態(tài)添加、移除表單,更加個(gè)性化的效果。
常見于填寫個(gè)人信息、附加內(nèi)容的表單
例如:
“工作經(jīng)歷”可以用戶自己點(diǎn)擊繼續(xù)添加按鈕,在原有的表單后面 append 多一個(gè)表單,不需要就點(diǎn)擊右上方 X 按鈕移除
問題
在實(shí)現(xiàn)之前,提出幾個(gè)問題
好吧,我當(dāng)時(shí)也思考了一會(huì),最后選擇數(shù)組方式,動(dòng)態(tài)渲染
代碼實(shí)現(xiàn)講解
利用數(shù)組,v-for 循環(huán)方式,可以完美實(shí)現(xiàn)動(dòng)態(tài)渲染和移除,因?yàn)椴僮鞯闹挥袑?duì)象數(shù)組而已
export default { name: 'vouchersDetail', data() { return { form: { regionName: '', regionCode: '', // 動(dòng)態(tài)添加的對(duì)象數(shù)組 azList: [ { azName: '', logicCode: '', physicCode: '' } ] } } }, computed: { // 至少保留一個(gè)動(dòng)態(tài)表單的開關(guān) isShowCloseBtn() { return this.form['azList'].length > 1 } }, methods: { addItem() { // 點(diǎn)擊添加表單的按鈕,只需要將表單綁定的 value 作為對(duì)象 push 到對(duì)象數(shù)組 this.form['azList'].push({ azName: '', logicCode: '', physicCode: '', weight: '' }) }, deleteItem(index) { // 點(diǎn)擊移除表單的按鈕,根據(jù)點(diǎn)擊的當(dāng)前 index 移除對(duì)象數(shù)組的元素 this.form['azList'].splice(index, 1) }, goBack() { window.history.back(-1) } } }
當(dāng)前名稱:vueelement動(dòng)態(tài)渲染、移除表單并添加驗(yàn)證的實(shí)現(xiàn)-創(chuàng)新互聯(lián)
本文路徑:http://www.chinadenli.net/article16/dcspdg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、響應(yīng)式網(wǎng)站、ChatGPT、標(biāo)簽優(yōu)化、網(wǎng)站設(shè)計(jì)公司、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容