欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vuejs學(xué)習(xí)筆記之使用指令v-model完成表單的數(shù)據(jù)雙向綁定

 更新時(shí)間:2019年04月29日 10:59:34   作者:張董  
表單類控件承載了一個(gè)網(wǎng)頁數(shù)據(jù)的錄入與交互,本章將介紹如何使用指令v-model完成表單的數(shù)據(jù)雙向綁定功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值。感興趣的朋友跟隨小編一起看看吧

表單類控件承載了一個(gè)網(wǎng)頁數(shù)據(jù)的錄入與交互,本章將介紹如何使用指令v-model完成表單的數(shù)據(jù)雙向綁定。

6.1 基本用法

表單控件在實(shí)際業(yè)務(wù)較為常見,比如單選、多選、下拉選擇、輸入框等,用它們可以完成數(shù)據(jù)的錄入、校驗(yàn)、提交等。
Vue.js提供了v-model指令,用于在表單類元素上雙向綁定數(shù)據(jù),例如在輸入框上使用時(shí),輸入的內(nèi)容會(huì)實(shí)時(shí)映射到綁定的數(shù)據(jù)上。

 例如下面的例子:

<div id="app">
 <input type="text" v-model="message" placeholder="請(qǐng)輸入...">
 <p>輸入的內(nèi)容是:{{message}}</p>
</div>

<script>
 var app = new Vue({
 el: "#app",
 data: {
 message: ""
 }
 });
</script>

在輸入框輸入的同時(shí),{{message}}也會(huì)實(shí)時(shí)將內(nèi)容渲染在視圖中。

 如圖6-1所示:

對(duì)于文本域<textarea>也是同樣的用法:

<div id="app">
 <textarea v-model="text" placeholder="請(qǐng)輸入..."></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)心初始化時(shí)的value屬性,對(duì)于在<textarea></textarea>之間插入的值,也不會(huì)生效。
  •  使用v-model時(shí),如果是用中文輸入法輸入中文,一般在沒有選定詞組前,也就是在拼音階段,Vue是不會(huì)更新數(shù)據(jù)的,當(dāng)敲下漢字時(shí)才會(huì)觸發(fā)鞥新。
  •  如果希望總是實(shí)時(shí)更新,可以用@input來替代v-model。
  •  事實(shí)上,v-model也是一個(gè)特殊的語法糖,只不過它會(huì)在不同的表單上智能處理。
  •  例如下面的示例:
<div id="app">
 <input type="text" @input="handleInput" placeholder="請(qǐng)輸入...">
 <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ú)使用時(shí),不需要v-model,直接使用v-bind綁定一個(gè)布爾類型的值,為true時(shí)選中,為false時(shí)不選。
 例如:

<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值一致時(shí),就會(huì)選中該項(xiàng),所以當(dāng)前狀態(tài)下選中的是第二項(xiàng)。
 如圖6-2所示:

復(fù)選框:

復(fù)選框也分單獨(dú)使用和組合使用,不過用法稍與單選不同。

 復(fù)選框單獨(dú)使用時(shí),也是用v-model來綁定一個(gè)布爾值。

 例如:

<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í),數(shù)據(jù)checked的值改為了true,<label>中渲染的內(nèi)容也會(huì)更新。

組合使用時(shí),也是v-model與value一起,多個(gè)勾選框都綁定到同一個(gè)數(shù)組類型的數(shù)據(jù),value的值在數(shù)據(jù)當(dāng)中,就會(huì)選中這一項(xiàng)。

 這一過程也是雙向的,在勾選時(shí),value的值也會(huì)自動(dòng)push到這個(gè)數(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>是備選項(xiàng),如果含有value屬性,v-model就會(huì)優(yōu)先匹配value的值; 

如果沒有,就會(huì)直接匹配<option>的text。

 比如選中第二項(xiàng)時(shí),selected的值為js,而不是JavaScript。

給<select>添加屬性multiple就可以多選了,此時(shí)v-model綁定的是一個(gè)數(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動(dòng)態(tài)輸出,value和text也是用v-bind來動(dòng)態(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>控件可以很簡(jiǎn)單地完成下拉選擇的需求,但是在實(shí)際業(yè)務(wù)中反而不常用,因?yàn)樗臉邮揭蕾嚻脚_(tái)和瀏覽器,無法統(tǒng)一,也不太美觀,功能也受限,,比如不支持搜索,所以常見的解決方案是用<div>moi一個(gè)類似的控件。

 當(dāng)閱讀完第7章組件的內(nèi)容后,可以嘗試編寫一個(gè)下拉選擇器的通用組件。

6.2 綁定值

上一節(jié)介紹的單選按鈕、復(fù)選框和選擇列表在單獨(dú)使用或單選的模式下,v-model綁定的值是一個(gè)靜態(tài)字符串或布爾值。
 但在業(yè)務(wù)中,有時(shí)需要綁定一個(gè)動(dòng)態(tài)的數(shù)據(jù),這時(shí)可以用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>

在選中時(shí),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>

 勾選時(shí),app.toggle===app.value1

 未勾選時(shí),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)選中時(shí),app.selected是一個(gè)Object,所以app.selected.number===123。

6.3 修飾符

與事件的修飾符類似,v-model也有修飾符,用于控制數(shù)據(jù)同步的時(shí)機(jī)。

.lazy:

在輸入框中,v-model默認(rèn)是在input事件中同步輸入框的數(shù)據(jù)(除了提示中介紹的中文輸入法情況外)。

 使用修飾符.lazy會(huì)轉(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í)時(shí)改變的,而是在失焦或按回車時(shí)才更新。

.number:

使用修飾符.number可以將輸入轉(zhuǎn)換為Number類型,否則雖然你輸入的是數(shù)字,但它的類型其實(shí)是String。
 比如在數(shù)字輸入框時(shí)會(huì)比較有用,示例代碼如下:

<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可以自動(dòng)過濾輸入的首尾空格,示例代碼如下:


<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é)會(huì)介紹。

以上所述是小編給大家介紹的Vuejs學(xué)習(xí)筆記之使用指令v-model完成表單的數(shù)據(jù)雙向綁定,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • Vue.js項(xiàng)目前端多語言方案的思路與實(shí)踐

    Vue.js項(xiàng)目前端多語言方案的思路與實(shí)踐

    前端的國際化是一個(gè)比較常見的需求,但網(wǎng)上關(guān)于這一方面的直接可用的方案卻不多,這篇文章主要給大家介紹了關(guān)于Vue.js項(xiàng)目前端多語言方案的思路與實(shí)踐,需要的朋友可以參考下
    2021-07-07
  • 使用Vite+Vue3+TypeScript?搭建開發(fā)腳手架的詳細(xì)過程

    使用Vite+Vue3+TypeScript?搭建開發(fā)腳手架的詳細(xì)過程

    這篇文章主要介紹了Vite+Vue3+TypeScript?搭建開發(fā)腳手架的詳細(xì)過程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • vue中的事件修飾符once,prevent,stop,capture,self,passive

    vue中的事件修飾符once,prevent,stop,capture,self,passive

    這篇文章主要介紹了vue中的事件修飾符once,prevent,stop,capture,self,passive,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 解析Vue 2.5的Diff算法

    解析Vue 2.5的Diff算法

    本文將對(duì)于Vue 2.5.3版本中使用的Virtual Dom進(jìn)行分析。updataChildren是Diff算法的核心,所以本文對(duì)updataChildren進(jìn)行了圖文的分析。下面通過本文給大家分享Vue 2.5的Diff算法,需要的朋友參考下吧
    2017-11-11
  • Vue中router.beforeEach與beforeRouteEnter的區(qū)別及說明

    Vue中router.beforeEach與beforeRouteEnter的區(qū)別及說明

    這篇文章主要介紹了Vue中router.beforeEach與beforeRouteEnter的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 解決ele ui 表格表頭太長問題的實(shí)現(xiàn)

    解決ele ui 表格表頭太長問題的實(shí)現(xiàn)

    這篇文章主要介紹了解決ele ui 表格表頭太長問題的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • vue3+uniapp 上傳附件的操作代碼

    vue3+uniapp 上傳附件的操作代碼

    uni-file-picker搭配uni.uploadFile在使用問題上踩了不少坑,我至今還是沒辦法在不改uniapp源碼基礎(chǔ)上實(shí)現(xiàn)限制重復(fù)文件的上傳,這篇文章介紹vue3+uniapp 上傳附件的操作代碼,感興趣的朋友一起看看吧
    2024-01-01
  • vue3中使用jsx的實(shí)現(xiàn)步驟

    vue3中使用jsx的實(shí)現(xiàn)步驟

    本文主要介紹了vue3中使用jsx的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • vue 綁定使用 touchstart touchmove touchend解析

    vue 綁定使用 touchstart touchmove touchend解析

    這篇文章主要介紹了vue 綁定使用 touchstart touchmove touchend解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue?@tap事件之$event用法介紹

    vue?@tap事件之$event用法介紹

    這篇文章主要介紹了vue?@tap事件之$event用法介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評(píng)論