Vue收集表單數據

在 Web 開發中,表單是用戶與系統交互的重要方式。無論是注冊、登錄、提交評論還是其他操作,都需要通過表單獲取用戶輸入的數據。Vue.js 提供了強大的響應式系統和指令,使得表單數據的收集變得簡單而高效。本文將詳細介紹如何在 Vue 中實現表單數據的收集與處理,包括基本輸入綁定、表單驗證以及常見注意事項。

一、基礎用法:使用 v-model 實現雙向綁定

Vue 提供了 v-model 指令來實現表單元素與組件數據之間的雙向綁定。這是最常用也是最推薦的方式。

示例:收集文本輸入

<template><div><label>姓名:</label><input type="text" v-model="formData.name" /><p>你輸入的名字是:{{ formData.name }}</p></div>
</template><script>
export default {data() {return {formData: {name: ''}}}
}
</script>

在這個例子中,當用戶在輸入框中輸入內容時,formData.name 會自動更新;反之,如果我們在 JS 中修改 formData.name,輸入框的內容也會同步變化。

示例:多類型表單控件綁定

1. 單選框(radio)
<label><input type="radio" value="男" v-model="formData.gender"> 男</label>
<label><input type="radio" value="女" v-model="formData.gender"> 女</label>
<p>性別:{{ formData.gender }}</p>
2. 復選框(checkbox)
  • 單個復選框綁定布爾值
<label><input type="checkbox" v-model="formData.isAgree"> 我同意協議</label>
<p>是否同意協議:{{ formData.isAgree ? '是' : '否' }}</p>
  • 多個復選框綁定數組
<label><input type="checkbox" value="籃球" v-model="formData.hobbies"> 籃球</label>
<label><input type="checkbox" value="足球" v-model="formData.hobbies"> 足球</label>
<label><input type="checkbox" value="羽毛球" v-model="formData.hobbies"> 羽毛球</label>
<p>愛好:{{ formData.hobbies.join('、') }}</p>
3. 下拉選擇框(select)
<select v-model="formData.favoriteColor"><option value="">請選擇顏色</option><option value="red">紅色</option><option value="blue">藍色</option><option value="green">綠色</option>
</select>
<p>最喜歡的顏色:{{ formData.favoriteColor }}</p>

二、高級用法:結合表單提交與驗證

1. 表單提交事件處理

通常我們使用 <form> 標簽包裹表單,并通過 @submit.prevent 阻止默認提交行為,進行自定義處理。

<template><form @submit.prevent="handleSubmit"><label>用戶名:<input type="text" v-model="formData.username"></label><br/><label>密碼:<input type="password" v-model="formData.password"></label><br/><button type="submit">提交</button></form>
</template><script>
export default {data() {return {formData: {username: '',password: ''}}},methods: {handleSubmit() {console.log('提交的數據為:', this.formData);// 可以在這里發起 API 請求}}
}
</script>

2. 表單驗證基礎

雖然 Vue 本身沒有內置的表單驗證機制,但我們可以手動添加驗證邏輯:

methods: {handleSubmit() {if (!this.formData.username.trim()) {alert('用戶名不能為空');return;}if (this.formData.password.length < 6) {alert('密碼不能少于6位');return;}// 提交數據console.log('驗證通過,提交數據:', this.formData);}
}

也可以使用第三方庫如 Vuelidate 或 VeeValidate 進行更復雜的驗證。

三、注意事項與最佳實踐

? 使用對象管理表單數據

避免將每個字段單獨放在 data() 中,建議統一放入一個 formData 對象中,便于維護和提交。

data() {return {formData: {username: '',email: '',age: null,gender: '',hobbies: []}}
}

? 正確使用 key 屬性

當動態渲染表單控件時,確保給每個組件設置唯一 key,防止 Vue 緩存舊數據。

? 清空表單數據

提交后清空表單是一個良好的用戶體驗:

this.formData = {username: '',password: '',gender: '',hobbies: []
};

? 避免直接操作 DOM

不要使用 ref 直接獲取并修改 input 的值,應始終使用 v-model 和數據驅動的方式控制表單狀態。

結語

感謝您的閱讀!如果你有任何疑問或想要分享的經驗,請在評論區留言交流!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/82831.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/82831.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/82831.shtml

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

相關文章

R基于多元線性回歸模型實現汽車燃油效率預測及SHAP值解釋項目實戰

說明&#xff1a;這是一個機器學習實戰項目&#xff08;附帶數據代碼文檔視頻講解&#xff09;&#xff0c;如需數據代碼文檔視頻講解可以直接到文章最后關注獲取。 1.項目背景 在全球環保意識日益增強和技術進步的推動下&#xff0c;汽車燃油效率成為了汽車行業關注的核心指標…

解決Window10上IP映射重啟失效的問題

問題 在實際網絡搭建過程中&#xff0c;大家有可能會遇到在局域網范圍內&#xff0c;在自己本機上搭建一個網站或者應用時&#xff0c;其他設備通過本機的IP地址無法訪問的問題,這個問題可以通過設置IP映射來解決&#xff0c;但是通過netsh interface命令設置的IP映射&#xf…

一臺手機怎樣實現多IP上網?方法有多種

在數字時代&#xff0c;多IP上網已成為許多手機用戶的剛需。本文將詳細介紹如何通過不同技術手段實現手機多IP上網&#xff0c;幫助讀者根據實際需求選擇適合的解決方案。 一、為什么一臺手機要實現多IP上網 手機實現多IP上網的典型場景包括&#xff1a; ①防止同一IP操作多個…

git子模塊--常見操作

克隆倉庫 標準化克隆流程 基本命令git clone <父倉庫遠程URL> [本地文件名] cd <本地倉庫名> git submodule init # 初始化子模塊配置 git submodule update # 拉取子模塊內容一次性完成克隆和初始化流程 基本命令git clone --recurse-submodules <父倉庫遠…

ceph 剔除 osd

剔除 osd 參考官網文檔 Removing OSDs (Manual) Removing the OSD 你得周期性地維護集群的子系統、或解決某個失敗域的問題(如一機架)。如果你不想在停機維護 OSD 時讓 CRUSH 自動重均衡,提前設置 noout ceph osd set nooutid=1# OSD 通常在從集群中移除之前處于 up in 在…

MySQL推出全新Hypergraph優化器,正式進軍OLAP領域!

在剛剛過去的 MySQL Summit 2025 大會上&#xff0c;Oracle 發布了一個用于 MySQL 的全新 Hypergraph&#xff08;超圖&#xff09;優化器&#xff0c;能夠為復雜的多表查詢生成更好的執行計劃&#xff0c;從而優化查詢性能。 這個功能目前只在 MySQL HeatWave 云數據庫中提供&…

破能所,入不二

一、緣起&#xff1a;從“聞所聞盡”到性相不二 《楞嚴經》觀世音菩薩耳根圓通法門的核心教義——“初于聞中&#xff0c;入流亡所&#xff1b;所入既寂&#xff0c;動靜二相&#xff0c;了然不生。如是漸增&#xff0c;聞所聞盡”&#xff0c;揭示了從凡夫二元認知躍升至究竟…

網站每天幾點更新,更新頻率是否影響網站收錄

1. 每天幾點更新網站最合適&#xff1f;總怕時間選錯影響收錄&#xff1f; 剛開始搞網站的時候&#xff0c;是不是老糾結啥時候更新合適&#xff1f;早上剛上班&#xff1f;半夜沒人的時候&#xff1f;選不對時間&#xff0c;總擔心搜索引擎爬蟲來了沒抓到新內容&#xff0c;影…

使用workvisual對庫卡機器人進行程序備份

1&#xff0c;將電腦網卡設置自動獲取&#xff0c;用網線將電腦與庫卡機器人控制柜上的網口連接 2&#xff0c;打開軟件后&#xff0c;會出現項目打開對話框&#xff0c;點擊瀏覽按鈕&#xff0c;會出現機器人站項目 3&#xff0c;點擊項目前面的?&#xff0c;展開菜單&…

2025.5.22 Axure 基礎與線框圖制作學習筆記

一、Axure 基礎 - 界面及相關了解 界面布局 工具欄 &#xff1a;位于軟件上方&#xff0c;包含新建、打開、保存等常用文件操作按鈕&#xff0c;以及撤銷、重做、剪切、復制、粘貼等編輯功能按鈕&#xff0c;方便快速執行相關操作。 元件面板 &#xff1a;在左側&#xff0c;提…

Python訓練打卡Day36

復習日&#xff1a; 回顧神經網絡的相關信息 1. 梯度下降的思想 梯度下降的本質是一種迭代優化算法&#xff0c;用于尋找函數的極小值點&#xff08;比如損失函數的最小值&#xff09;其關鍵的要素如下 梯度&#xff1a;函數在某點變化率最大方向學習率&#xff1a;每一步的…

【Android】System分區應用自帶庫與原生庫同名問題分析

System分區應用自帶庫與原生庫同名問題分析 問題背景 某系統應用發生必現崩潰問題。崩潰log如下 0*-** **:**:**.** 66666 66666 E ***** aar error:: java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "_TTT_TTT_TTT" referenced by &quo…

計算機網絡中的單播、組播與廣播

文章目錄 前言一、單播&#xff08;Unicast&#xff09;1.1 定義與工作原理1.2 優點1.3 缺點1.4 典型應用場景 二、廣播&#xff08;Broadcast&#xff09;2.1 定義與工作原理2.2 優點2.3 缺點2.4 典型應用場景 三、組播&#xff08;Multicast&#xff09;3.1 定義與工作原理3.…

ASP.NET MVC添加新控制器示例

ASP.NET MVC高效構建Web應用- 商品搜索 - 京東 控制器&#xff08;Controllers&#xff09;是一個協調視圖和模型直接關系的特殊類。它響應用戶輸入&#xff0c;與模型進行對話&#xff0c;并決定呈現哪個視圖&#xff08;如果有的話&#xff09;。在ASP.NET MVC中&#xff0c…

Escrcpy(安卓手機投屏軟件) v1.29.6 中文綠色版

在數字設備日益普及的今天&#xff0c;用戶對于設備的控制和管理需求也在不斷增加。對于Android設備用戶來說&#xff0c;Escrcpy這款強大的工具無疑是一個福音。它不僅提供了直觀的圖形化界面&#xff0c;讓用戶能夠輕松顯示和控制自己的Android設備&#xff0c;還以完全免費開…

Python爬蟲實戰:研究Goose框架相關技術

一、引言 隨著互聯網的迅速發展,網絡上的信息量呈爆炸式增長。從海量的網頁中提取有價值的信息成為一項重要的技術。網絡爬蟲作為一種自動獲取網頁內容的程序,在信息收集、數據挖掘、搜索引擎等領域有著廣泛的應用。本文將詳細介紹如何使用 Python 的 Goose 框架構建一個完整…

【Linux 學習計劃】-- 馮諾依曼體系 | 操作系統的概念與定位,以及其如何管理軟件

目錄 馮諾依曼體系結構 操作系統是干什么的&#xff1f; 理解操作系統中的管理 對OS&#xff08;操作系統&#xff09;宏觀、整體的分析 總結 結語 馮諾依曼體系結構 首先我們來看這樣一張圖&#xff0c;這就是大名鼎鼎的馮諾依曼體系 在日常生活中&#xff0c;所有的計…

新消息!阿里云ACP大模型認證有變化!

阿里云ACP認證是阿里云認證中的高級工程師&#xff0c;ACP認證方向有云計算、大數據、人工智能、大模型等多個&#xff0c;大家都知道&#xff0c;阿里云ACP考試題量共100題&#xff0c;其中70道單選題30道多選題&#xff0c;每題一分&#xff0c;滿分100分&#xff0c;80分合格…

MySQL 數據遷移Postgresql(openGuass) 之 pg_chameleon

1 pg_chameleon 介紹 pgchameleon 是一款MySQL 到 PostgreSQL/openGuass 的復制工具。 pg_chameleon 使用場景&#xff1a; 1&#xff09;分析 2&#xff09;遷移 3&#xff09;對多個MySQL 數據庫進行數據聚合 操作系統信息 (myenv) rootu24-pg-60:~# cat /etc/issue Ubuntu …

Spark 中,map和foreach的區別

在 Spark 中&#xff0c;map和foreach是兩種不同用途的轉換操作&#xff0c;主要區別在于&#xff1a; 1. 操作類型與返回值 map&#xff1a;是轉換操作&#xff08;Transformation&#xff09;&#xff0c;返回一個新的 RDD。foreach&#xff1a;是行動操作&#xff08;Acti…