在?Vue?中控制表單輸入方法詳解
Vue中v-model的思路很簡單。定義一個可響應式的text(通常是一個ref),然后用v-model="text"將這個值綁定到一個input上。這就創(chuàng)造了一個雙向的數(shù)據(jù)流:
用戶在輸入框中輸入,text會發(fā)生變化。 text發(fā)生變化,輸入框的值也隨之變化。
讓我們看看如何在Vue 3中使用v-model來控制表單輸入。
綁定表單輸入
讓我們實現(xiàn)一個組件,渲染一個初始值為Unknown的輸入表單。用戶在輸入表單中引入的值會在屏幕上渲染出來。
v-model很適合實現(xiàn)這樣一個組件。將v-model與輸入表單連接起來需要兩個簡單的步驟:
const text = ref():作為v-model可響應式的值。 v-model="text":將v-model添加到分配有text的輸入表單標簽中。
<script setup>
import { ref } from 'vue'
const text = ref('Unknown') // Step 1: create data bus
</script>
<template>
<!-- Step 2: assign data bus to v-model -->
<input v-model="text" type="input" />
<div>{{ text }}</div>
</template>輸入表單包含初始值Unknown。在輸入表單里輸入一些東西:輸入值和屏幕上的文本都會更新。
v-model="text" 在Vue中屬于雙向綁定數(shù)據(jù)。
第一個方向的流動發(fā)生在初始化過程中。輸入值被初始化為Unknown,也就是text的初始值。
第二個方向的流動發(fā)生在給輸入表單鍵入值的時候。v-model接受輸入框的值,并用它來更新text。

v-model與v-bind
在Vue中,v-bind是另一種數(shù)據(jù)綁定機制:
<input v-bind:value="text" type="text" />
可以簡寫為:
<input :value="text" type="text" />
v-model和:value的不同之處是什么?<input :value="value" />是一種單向數(shù)據(jù)流機制。
為了理解兩者的不同之處,讓我們將先前的例子從v-model="text"改為:value="text":
<script setup>
import { ref } from 'vue'
const text = ref('Unknown')
</script>
<template>
<input :value="text" type="input" />
<div>{{ text }}</div>
</template>輸入表單的初始值為Unknown。
在輸入表單中鍵入一些字符,然而…屏幕上渲染的文本依舊是Unknown。
:value="text"讓數(shù)據(jù)流僅僅單向流動:從text流向輸入表單。當改變數(shù)據(jù)表單的值時,并不會改變text。

總之,v-model實現(xiàn)了雙向數(shù)據(jù)流,而:value實現(xiàn)了單向數(shù)據(jù)流。
模擬v-model
盡管兩者有差異,但是v-model可以使用:value和@input進行模擬:
<input v-model="text" type="text" />
也可以表示為:
<input :value="text" @input="text = $event.target.value" type="text" />
下面的代碼沒有使用v-model,但雙向數(shù)據(jù)流仍然生效:
<script setup>
import { ref } from 'vue'
const text = ref('Unknown')
</script>
<template>
<input
:value="text"
@input="text = $event.target.value"
type="input"
/>
<div>{{ text }}</div>
</template>常規(guī)綁定:value="text"開啟了第一個流程。
當用戶在輸入表單中輸入時會觸發(fā)@input="text = $event.target.value",從而更新text。這就是第二個流程。
使用reactive()綁定
reactive()是Vue里的響應式API,可以讓對象具有響應式。
ref()和reactive()的最大不同點就是,ref()可以存儲原始值和對象,而reactive()值接受對象。并且reactive()對象可以直接訪問,而不需要像ref()那樣需要通過.value屬性訪問。
讓我們實現(xiàn)一個具有姓氏和名字的輸入表單,并將這些綁定到一個響應式對象的屬性上:
<script setup>
import { reactive } from 'vue'
const person = reactive({ firstName: 'John', lastName: 'Smith' })
</script>
<template>
<input v-model="person.firstName" type="input" />
<input v-model="person.lastName" type="input" />
<div>Full name is {{ person.firstName }} {{ person.lastName }}</div>
</template>const person = reactive({ firstName: '', lastName: '' })創(chuàng)建了一個響應式的對象。
v-model="person.firstName"與名字屬性綁定,以及v-model="person.lastName"與姓氏屬性綁定。
一個響應式對象的屬性可以作為v-model的數(shù)據(jù)總線??梢允褂眠@種方法來綁定許多輸入表單。
綁定不同輸入類型
許多其他的輸入類型比如說select、textarea、checkbox、radio都可以使用v-model綁定。讓我們來試試吧。
Textarea
為textarea綁定一個ref是非常直截了當?shù)摹V恍枰?code>textarea標簽上使用v-model即可:
<script setup>
import { ref } from 'vue'
const longText = ref("Well... here's my story. One morning...")
</script>
<template>
<textarea v-model="longText" />
<div>{{ longText }}</div>
</template>Select
select也就是下拉框,為用戶提供了一組預定義的選項供其選擇。
綁定下拉框也是非常簡單的:
<script setup>
import { ref } from 'vue'
const employeeId = ref('2')
</script>
<template>
<select v-model="employeeId">
<option value="1">Jane Doe</option>
<option value="2">John Doe</option>
<option value="3">John Smith</option>
</select>
<div>Selected id: {{ employeeId }}</div>
</template>employeeId是與select綁定的ref,將獲得被選擇的選項的值。
因為employeeId被初始化為'2',因此John Doe選項會被選中。
當你選擇另一個選項時,你可以看到employeeId以新選擇的選項值進行更新。
如果select的選項沒有value屬性,那么就用選項的文本值進行綁定:
<script setup>
import { ref } from 'vue'
const employee = ref('Jane Doe')
</script>
<template>
<select v-model="employee">
<option>Jane Doe</option>
<option>John Doe</option>
<option>John Smith</option>
</select>
<div>Selected: {{ employee }}</div>
</template>現(xiàn)在,綁定直接與選項的文本值共同生效。如果你選擇了第二個選項,那么employee將被分配為"John Doe"。
Checkbox
感謝v-model讓綁定復選框很容易:
<input ref="checked" type="checkbox" />
checked被賦予一個布爾值,表示該復選框是否被選中。
讓我們創(chuàng)建一個復選框,并綁定checked:
<script setup>
import { ref } from 'vue'
const checked = ref(true)
</script>
<template>
<label><input v-model="checked" type="checkbox" />Want a pizza?</label>
<div>{{ checked }}</div>
</template>checked的初始值是true,因此復選框默認是被選中的。勾選或不勾選復選框,會相應地將checked更新為true或false。
為了將勾選或不勾選綁定到布爾值以外的其他自定義值,Vue在復選框上提供了2個Vue特有的屬性:
<input v-model="checked" true-value="Yes!" false-value="No" />
現(xiàn)在,checked被賦值為'Yes!'或'No'字符串,這取決于復選框的狀態(tài)。
讓我們使用自定義值'Yes!'和'No'來修改先前的例子:
<script setup>
import { ref } from 'vue'
const answer = ref('Yes!')
</script>
<template>
<label>
<input v-model="answer" type="checkbox" true-value="Yes!" false-value="No" />
Want a pizza?
</label>
<div>{{ answer }}</div>
</template>現(xiàn)在,answer是'Yes!'或'No'取決于復選框的選中狀態(tài)。
Radio
要綁定一組單選按鈕,要對該單選組應用相同的總線綁定v-model="option":
<input type="radio" v-model="option" value="a" /> <input type="radio" v-model="option" value="b" /> <input type="radio" v-model="option" value="c" />
舉個例子,讓我們實現(xiàn)一組單選按鈕,來選擇T恤的顏色:
<script setup>
import { ref } from "vue"
const color = ref("white")
</script>
<template>
<label><input type="radio" v-model="color" value="white" />White</label>
<label><input type="radio" v-model="color" value="red" />Red</label>
<label><input type="radio" v-model="color" value="blue" />Blue</label>
<div>T-shirt color: {{ color }}</div>
</template>初始情況下,White單選框會被選中,因為color的初始值為'white'。
點擊其他任意T恤顏色,并根據(jù)選定的顏色改變color。
單選框的value屬性是可綁定的:你可以使用:value。當選項列表來自一個數(shù)組時這很有幫助:
<script setup>
import { ref } from "vue"
const color = ref("white")
const COLORS = [
{ option: "white", label: "White" },
{ option: "black", label: "Black" },
{ option: "blue", label: "Blue" },
]
</script>
<template>
<label v-for="{ option, label } in COLORS" :key="option">
<input type="radio" v-model="color" :value="option" /> {{ label }}
</label>
<div>T-shirt color: {{ color }}</div>
</template>v-model修飾符
除了在綁定表單輸入方面做得很好之外,v-model還有一個額外的功能,叫做修飾符。
修飾符是應用于v-model的一段邏輯,用于自定義其行為。修飾符通過使用點語法v-model.<modifier>應用于v-model,例如v-mode.trim。
默認情況下,Vue提供了3個修飾符,trim、number和lazy。
trim
清除一個字符串是指刪除字符串開頭和結尾的空白處。例如,清除應用于' Wow! '的結果是'Wow!'。
v-model.trim修飾符在賦值給綁定的ref之前清除輸入表單的值:
<script setup>
import { ref } from 'vue'
const text = ref('')
</script>
<template>
<input v-model.trim="text" type="text" />
<pre>"{{ text }}"</pre>
</template>number
v-model.number修飾符在輸入表單的值上應用一個數(shù)字解析器。
如果用戶引入了一個可以解析為數(shù)字的值,v-model.number="number"則將解析后的數(shù)字分配給number。在其他情況下,如果引入的值不是數(shù)字,number就會被分配為原始字符串。
<script setup>
import { ref } from "vue";
const number = ref("");
</script>
<template>
<input v-model.number="number" type="text" />
<div>{{ typeof number }}</div>
</template>當你在input中引入'345',那么number就會變成345(一個數(shù)字)。值解析會自動發(fā)生。
但是如果你在input中引入一個非數(shù)值,比如'abc',那么number就會被分配為相同的值'abc'。
lazy
默認情況下,當綁定的值更新時,v-model會使用input事件。但如果使用修飾符v-model.lazy,你可以將該事件改為change事件。
input和change事件的主要區(qū)別是什么呢?
input是每當你在輸入表單鍵入時就會觸發(fā)。 change是只有當你把焦點從輸入表單移開時,才會觸發(fā)。在輸入表單里輸入并不會觸發(fā)change事件。
下面示例使用了lazy綁定:
<script setup>
import { ref } from 'vue'
const text = ref('Unknown')
</script>
<template>
<input v-model.lazy="text" type="input" />
<div>{{ text }}</div>
</template>如果你有一個許多輸入字段和大量狀態(tài)的表單,你可以應用lazy修飾符來禁用用戶輸入時的實時響應。這可以防止輸入時頁面卡住。
總結
v-model將表單輸入與ref或響應式對象進行綁定。
綁定是通過兩個簡單的步驟實現(xiàn)的:
首先,通過const text = ref('')創(chuàng)建ref 。 其次,將 ref 分配給 v-model 屬性:<input v-model="text" type="text" />。
以上就是本文的全部內容,如果對你有所幫助,歡迎點贊、收藏、轉發(fā)~
到此這篇關于在 Vue 中控制表單輸入方法詳解的文章就介紹到這了,更多相關在 Vue 中控制表單輸入內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue集成kindeditor富文本的實現(xiàn)示例代碼
這篇文章主要介紹了vue集成kindeditor富文本的實現(xiàn)示例代碼,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-06-06
Vue使用antd組件a-form-model實現(xiàn)數(shù)據(jù)連續(xù)添加功能
這篇文章主要介紹了Vue使用antd組件a-form-model實現(xiàn)數(shù)據(jù)連續(xù)添加功能,本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-12-12
基于vue-cli配置lib-flexible + rem實現(xiàn)移動端自適應
這篇文章主要介紹了基于vue-cli配置lib-flexible + rem實現(xiàn)移動端自適應,需要的朋友可以參考下2017-12-12
使用vue-cli創(chuàng)建項目并webpack打包的操作方法
本文給大家分享使用vue-cli創(chuàng)建項目基于webpack模板打包的配置方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-07-07

