Vuejs學(xué)習(xí)筆記之使用指令v-model完成表單的數(shù)據(jù)雙向綁定
表單類控件承載了一個網(wǎng)頁數(shù)據(jù)的錄入與交互,本章將介紹如何使用指令v-model完成表單的數(shù)據(jù)雙向綁定。
6.1 基本用法
表單控件在實(shí)際業(yè)務(wù)較為常見,比如單選、多選、下拉選擇、輸入框等,用它們可以完成數(shù)據(jù)的錄入、校驗(yàn)、提交等。
Vue.js提供了v-model
指令,用于在表單類元素上雙向綁定數(shù)據(jù),例如在輸入框上使用時,輸入的內(nèi)容會實(shí)時映射到綁定的數(shù)據(jù)上。
例如下面的例子:
<div id="app"> <input type="text" v-model="message" placeholder="請輸入..."> <p>輸入的內(nèi)容是:{{message}}</p> </div> <script> var app = new Vue({ el: "#app", data: { message: "" } }); </script>
在輸入框輸入的同時,{{message}}
也會實(shí)時將內(nèi)容渲染在視圖中。
如圖6-1所示:
對于文本域<textarea>也是同樣的用法:
<div id="app"> <textarea v-model="text" placeholder="請輸入..."></textarea> <p>輸入的內(nèi)容是:</p> <p style="white-space: pre;">{{text}}</p> </div> <script> var app = new Vue({ el: "#app", data: { text: "" } }); </script>
提示:
- 提示v-model后,表單控件顯示的值只依賴所綁定的數(shù)據(jù),不再關(guān)心初始化時的value屬性,對于在<textarea></textarea>之間插入的值,也不會生效。
- 使用v-model時,如果是用中文輸入法輸入中文,一般在沒有選定詞組前,也就是在拼音階段,Vue是不會更新數(shù)據(jù)的,當(dāng)敲下漢字時才會觸發(fā)鞥新。
- 如果希望總是實(shí)時更新,可以用@input來替代v-model。
- 事實(shí)上,v-model也是一個特殊的語法糖,只不過它會在不同的表單上智能處理。
- 例如下面的示例:
<div id="app"> <input type="text" @input="handleInput" placeholder="請輸入..."> <p>輸入的內(nèi)容是:{{message}}</p> </div> <script> var app = new Vue({ el: "#app", data: { message: "" }, methods: { handleInput: function(event) { this.message = event.target.value; } } }); </script>
來看看更多的表單控件。
單選按鈕:
單選按鈕在單獨(dú)使用時,不需要v-model,直接使用v-bind綁定一個布爾類型的值,為true時選中,為false時不選。
例如:
<div id="app"> <input type="radio" :checked="picked"> <label>單選按鈕</label> </div> <script> var app = new Vue({ el: "#app", data: { picked: true } }); </script>
如果是組合使用來實(shí)現(xiàn)互斥選擇的效果,就需要v-model配合value來使用:
<div id="app"> <input type="radio" v-model="picked" value="html" id="html"> <label for="html">HTML</label> <input type="radio" v-model="picked" value="js" id="js"> <label for="js">JavaScript</label> <input type="radio" v-model="picked" value="css" id="css"> <label for="css">CSS</label> <p>您選擇的是:{{picked}}</p> </div> <script> var app = new Vue({ el: "#app", data: { picked: "js" } }); </script>
數(shù)據(jù)picked的值與表單按鈕的value值一致時,就會選中該項,所以當(dāng)前狀態(tài)下選中的是第二項。
如圖6-2所示:
復(fù)選框:
復(fù)選框也分單獨(dú)使用和組合使用,不過用法稍與單選不同。
復(fù)選框單獨(dú)使用時,也是用v-model來綁定一個布爾值。
例如:
<div id="app"> <input type="checkbox" v-model="checked" id="checked"> <label for="checked">選擇狀態(tài):{{checked}}</label> </div> <script> var app = new Vue({ el: "#app", data: { checked: false } }); </script>
在勾選時,數(shù)據(jù)checked的值改為了true,<label>中渲染的內(nèi)容也會更新。
組合使用時,也是v-model與value一起,多個勾選框都綁定到同一個數(shù)組類型的數(shù)據(jù),value的值在數(shù)據(jù)當(dāng)中,就會選中這一項。
這一過程也是雙向的,在勾選時,value的值也會自動push到這個數(shù)組中。
實(shí)例代碼如下:
<div id="app"> <input type="checkbox" v-model="checked" value="html" id="html"> <label for="html">HTML</label> <br> <input type="checkbox" v-model="checked" value="js" id="js"> <label for="js">JavaScript</label> <br> <input type="checkbox" v-model="checked" value="css" id="css"> <label for="css">CSS</label> <br> <p>你選擇的是:{{checked}}</p> </div> <script> var app = new Vue({ el: "#app", data: { checked: ["html", "css"] } }); </script>
當(dāng)前狀態(tài)下的結(jié)果如圖6-3所示:
選擇列表:
選擇列表就是下拉選擇器,也是常見的表單控件,同樣也分為單選和多選兩種方式。
先看一下單選的示例代碼:
<div id="app"> <select v-model="selected"> <option>html</option> <option value="js">JavaScript</option> <option>css</option> </select> <p>你選擇的是:{{selected}}</p> </div> <script> var app = new Vue({ el: "#app", data: { selected: "html" } }); </script>
<option>是備選項,如果含有value屬性,v-model就會優(yōu)先匹配value的值;
如果沒有,就會直接匹配<option>的text。
比如選中第二項時,selected的值為js,而不是JavaScript。
給<select>添加屬性multiple就可以多選了,此時v-model綁定的是一個數(shù)組,與復(fù)選框用法類似。
實(shí)例代碼如下:
<div id="app"> <select v-model="selected" multiple> <option>html</option> <option value="js">JavaScript</option> <option>css</option> </select> <p>你選擇的是:{{selected}}</p> </div> <script> var app = new Vue({ el: "#app", data: { selected: ["html", "js"] } }); </script>
在業(yè)務(wù)中,<option>經(jīng)常用v-for動態(tài)輸出,value和text也是用v-bind來動態(tài)輸出的。
例如:
<div id="app"> <select v-model="selected"> <option v-for="item in options" :value="item.value">{{item.text}}</option> </select> <p>你選擇的是:{{selected}}</p> </div> <script> var app = new Vue({ el: "#app", data: { options: [ {text:"HTML", value:"html"}, {text:"JavaScript", value:"js"}, {text:"CSS", value:"css"}, ], selected: "html" } }); </script>
雖然用選擇列表<select>控件可以很簡單地完成下拉選擇的需求,但是在實(shí)際業(yè)務(wù)中反而不常用,因?yàn)樗臉邮揭蕾嚻脚_和瀏覽器,無法統(tǒng)一,也不太美觀,功能也受限,,比如不支持搜索,所以常見的解決方案是用<div>moi一個類似的控件。
當(dāng)閱讀完第7章組件的內(nèi)容后,可以嘗試編寫一個下拉選擇器的通用組件。
6.2 綁定值
上一節(jié)介紹的單選按鈕、復(fù)選框和選擇列表在單獨(dú)使用或單選的模式下,v-model綁定的值是一個靜態(tài)字符串或布爾值。
但在業(yè)務(wù)中,有時需要綁定一個動態(tài)的數(shù)據(jù),這時可以用v-bind來實(shí)現(xiàn)。
單選按鈕:
<div id="app"> <input type="radio" v-model="picked" :value="value"> <label>單選按鈕</label> <p>{{picked}}</p> <p>{{value}}</p> </div> <script> var app = new Vue({ el: "#app", data: { picked: false, value: 123 } }); </script>
在選中時,app.picked===app.value
,值都是123。
復(fù)選框:
<div id="app"> <input type="checkbox" v-model="toggle" :true-value="value1" :false-value="value2"> <label>復(fù)選框</label> <p>{{toggle}}</p> <p>{{value1}}</p> <p>{{value2}}</p> </div> <script> var app = new Vue({ el: "#app", data: { toggle: false, value1: "a", value2: "b" } }); </script>
勾選時,app.toggle===app.value1
;
未勾選時,app.toggle===app.value2
。
選擇列表:
<div id="app"> <select v-model="selected"> <option :value="{number:123}">123</option> </select> {{selected.number}} </div> <script> var app = new Vue({ el: "#app", data: { selected: "" } }); </script>
當(dāng)選中時,app.selected是一個Object,所以app.selected.number===123
。
6.3 修飾符
與事件的修飾符類似,v-model也有修飾符,用于控制數(shù)據(jù)同步的時機(jī)。
.lazy:
在輸入框中,v-model默認(rèn)是在input事件中同步輸入框的數(shù)據(jù)(除了提示中介紹的中文輸入法情況外)。
使用修飾符.lazy會轉(zhuǎn)變?yōu)樵赾hange事件中同步,示例代碼如下:
<div id="app"> <input type="text" v-model.lazy="message"> <p>{{message}}</p> </div> <script> var app = new Vue({ el: "#app", data: { message: "" } }); </script>
這是,message并不是實(shí)時改變的,而是在失焦或按回車時才更新。
.number:
使用修飾符.number可以將輸入轉(zhuǎn)換為Number類型,否則雖然你輸入的是數(shù)字,但它的類型其實(shí)是String。
比如在數(shù)字輸入框時會比較有用,示例代碼如下:
<div id="app"> <input type="number" v-model.number="message"> <p>{{typeof message}}</p> </div> <script> var app = new Vue({ el: "#app", data: { message: 123 } }); </script>
.trim:
修飾符.trim可以自動過濾輸入的首尾空格,示例代碼如下:
<div id="app"> <input type="text" v-model.trim="message"> <p>{{message}}</p> </div> <script> var app = new Vue({ el: "#app", data: { message: "" } }); </script>
從Vue.js 2.x開始,v-model還可以用于自定義組件,滿足定制化的需求,在下一節(jié)會介紹。
以上所述是小編給大家介紹的Vuejs學(xué)習(xí)筆記之使用指令v-model完成表單的數(shù)據(jù)雙向綁定,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
使用Vite+Vue3+TypeScript?搭建開發(fā)腳手架的詳細(xì)過程
這篇文章主要介紹了Vite+Vue3+TypeScript?搭建開發(fā)腳手架的詳細(xì)過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-02-02vue中的事件修飾符once,prevent,stop,capture,self,passive
這篇文章主要介紹了vue中的事件修飾符once,prevent,stop,capture,self,passive,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04Vue中router.beforeEach與beforeRouteEnter的區(qū)別及說明
這篇文章主要介紹了Vue中router.beforeEach與beforeRouteEnter的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10解決ele ui 表格表頭太長問題的實(shí)現(xiàn)
這篇文章主要介紹了解決ele ui 表格表頭太長問題的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11vue 綁定使用 touchstart touchmove touchend解析
這篇文章主要介紹了vue 綁定使用 touchstart touchmove touchend解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03