我們可以使用 Vue.js 中的 v-model 指令來完成表單數(shù)據(jù)的雙向綁定忘晤。
1 基礎(chǔ)用法
1.1 文本輸入框(text)
這里演示了在文本輸入框上輸入的內(nèi)容,會(huì)實(shí)時(shí)映射到綁定的數(shù)據(jù)上激捏。
html:
<div id="app">
<input type="text" v-model="content" placeholder="請(qǐng)輸入">
<p>輸入框:{{content}}</p>
</div>
js:
<script>
var app = new Vue({
el: '#app',
data: {
content: ''
}
});
</script>
效果:
1.2 大文本輸入框(textarea)
綁定方法與文本輸入框相同设塔。
html:
<div id="app2">
<textarea v-model="content" placeholder="請(qǐng)輸入"></textarea>
<p>內(nèi)容:</p>
<p style="white-space: pre">{{content}}</p>
</div>
js:
var app2 = new Vue({
el: '#app2',
data: {
content: ''
}
});
效果:
這里對(duì)展示的內(nèi)容所對(duì)應(yīng)的 <p>
元素加了 white-space: pre
樣式,這樣內(nèi)容即使帶有回車符也會(huì)保留远舅。
注意:表單控件所顯示的值只依賴于所綁定的數(shù)據(jù)闰蛔,所以即便設(shè)置了表單控件中的 value值,也不會(huì)起作用哦图柏。同理序六,<textarea>xxx</textarea>
之間的值也無效。
之前的示例我們可以發(fā)現(xiàn)蚤吹,使用中文輸入法時(shí)例诀,只有確定選中的詞語,才會(huì)被如果 Vue.js 所更新裁着。如果希望輸入的內(nèi)容實(shí)時(shí)更新繁涂,那么可以使用 @input
。
html:
<div id="app3">
<textarea @input="inputHandler" placeholder="請(qǐng)輸入"></textarea>
<p>內(nèi)容:</p>
<p style="white-space: pre">{{content}}</p>
</div>
js:
var app3 = new Vue({
el: '#app3',
data: {
content: ''
},
methods: {
inputHandler: function (event) {
this.content = event.target.value;
}
}
});
可以看出跨算,即使在 @input
定義的函數(shù)不帶參數(shù)爆土,Vue.js 也會(huì)在定義的函數(shù)(示例中的 inputHandler)中傳入 event 原生事件對(duì)象。
效果:
1.3 單選框
單選框一般都有多個(gè)條件可供選擇诸蚕,既然是單選框步势,自然希望實(shí)現(xiàn)互斥效果,我們可以使用 v-model 指令配合單選框的 value 來實(shí)現(xiàn)背犯。
html:
<div id="app4">
<input id="radio1" type="radio" v-model="checked" value="文學(xué)">
<label for="radio1">文學(xué)</label>
<input id="radio2" type="radio" v-model="checked" value="藝術(shù)">
<label for="radio2">藝術(shù)</label>
<input id="radio3" type="radio" v-model="checked" value="經(jīng)濟(jì)">
<label for="radio3">經(jīng)濟(jì)</label>
<br>
<p>選擇了:{{checked}}</p>
</div>
js:
var app4 = new Vue({
el: '#app4',
data: {
checked: '文學(xué)'
}
});
效果:
1.4 復(fù)選框
復(fù)選框的綁定方式與單選框相同坏瘩,只不過復(fù)選框所對(duì)應(yīng)的數(shù)據(jù)類型是數(shù)組罷了。
html:
<div id="app5">
<input id="checkbox1" type="checkbox" v-model="checked" value="文學(xué)">
<label for="checkbox1">文學(xué)</label>
<input id="checkbox2" type="checkbox" v-model="checked" value="藝術(shù)">
<label for="checkbox2">藝術(shù)</label>
<input id="checkbox3" type="checkbox" v-model="checked" value="經(jīng)濟(jì)">
<label for="checkbox3">經(jīng)濟(jì)</label>
<br>
<p>選擇了:{{checked}}</p>
</div>
js:
var app5 = new Vue({
el: '#app5',
data: {
checked: ['文學(xué)','藝術(shù)']
}
});
效果:
1.5 下拉選擇框
1.5.1 單選
html:
<div id="app6">
<select v-model="selected">
<option value="1">文學(xué)</option>
<option value="2">藝術(shù)</option>
<option>經(jīng)濟(jì)</option>
</select>
<br>
<p>選擇了:{{selected}}</p>
</div>
js:
var app6 = new Vue({
el: '#app6',
data: {
selected: '1'
}
});
效果:
可以看出漠魏,如果 <option>
含有 value 值倔矾,則會(huì)先匹配該值;如果沒有柱锹,則匹配 <option>
中的 text 值(比如示例中的 <option>經(jīng)濟(jì)</option>
)哪自。
1.5.2 多選
為 <select>
標(biāo)簽添加 multiple 屬性,即可實(shí)現(xiàn)多選禁熏。
html:
<div id="app7">
<select v-model="selected" multiple>
<option value="1">文學(xué)</option>
<option value="2">藝術(shù)</option>
<option>經(jīng)濟(jì)</option>
</select>
<br>
<p>選擇了:{{selected}}</p>
</div>
在實(shí)際應(yīng)用場(chǎng)景壤巷,<select>
標(biāo)簽中的 <opinion>
一般是通過 v-for 指令動(dòng)態(tài)輸出的,其中每一項(xiàng)的 value 或 text 都可以使用 v-bind 動(dòng)態(tài)輸出的瞧毙。
html:
<div id="app8">
<select v-model="selected">
<option v-for="option in options"
:value="option.value">{{option.text}}
</option>
</select>
<br>
<p>選擇了:{{selected}}</p>
</div>
js:
var app8 = new Vue({
el: '#app8',
data: {
selected: '1',
options: [
{text: '文學(xué)', value: '1'},
{text: '藝術(shù)', value: '2'}
]
}
});
效果:
因?yàn)?select 標(biāo)簽的呈現(xiàn)樣式依賴于瀏覽器胧华,所以在實(shí)際業(yè)務(wù)場(chǎng)景中寄症,我們更多的是使用 div 來模擬 select 標(biāo)簽的列表功能,而這可以通過使用 Vue.js 自定義組件的方式來實(shí)現(xiàn)一個(gè)通用的下拉選擇組件矩动。
以上示例 DEMO
2 綁定動(dòng)態(tài)變量
之前所說的示例有巧,v-model 綁定的都是靜態(tài)變量。我們可以使用 v-bind 來綁定動(dòng)態(tài)變量悲没。
2.1 單選框
html:
<div id="app">
<input id="radio1" type="radio" v-model="picked" :value="value">
<label for="radio1">文學(xué)</label>
<input id="radio2" type="radio" v-model="picked" :value="value2">
<label for="radio2">藝術(shù)</label>
<input id="radio3" type="radio" v-model="picked" :value="value3">
<label for="radio3">經(jīng)濟(jì)</label>
<br>
<p>{{picked}}</p>
<p>{{value}},{{value2}},{{value3}}</p>
</div>
js:
var app = new Vue({
el: '#app',
data: {
picked: false,
value: '文學(xué)',
value2: '藝術(shù)',
value3: '經(jīng)濟(jì)',
}
});
效果:
示例中定義的單選框默認(rèn)值為 picked 所定義的 false篮迎。當(dāng)選中某個(gè)單選框時(shí),則動(dòng)態(tài)綁定在 :value
中定義的變量示姿。
2.2 復(fù)選框
html:
<div id="app2">
<input id="checkbox" type="checkbox" v-model="checked" :true-value="value1" :false-value="value2">
<label for="checkbox">開關(guān)</label>
<p>checked:{{checked}}</p>
<p>value1:{{value1}}</p>
<p>value2:{{value2}}</p>
</div>
js:
var app2 = new Vue({
el: '#app2',
data: {
value1: '亮',
value2: '暗',
checked: ''
}
});
效果:
復(fù)選框的默認(rèn)值綁定的是 v-model 定義的變量柑潦,而勾選與取消勾選所綁定的值,則分別由 :true-value
與 false-value
來實(shí)現(xiàn)動(dòng)態(tài)綁定峻凫。
2.3 下拉選擇框
html:
<div id="app3">
<select v-model="selected">
<option :value="{number:1}">文學(xué)</option>
<option :value="{number:2}">藝術(shù)</option>
</select>
<br>
<p>選擇了:{{selected.number}}</p>
</div>
js:
var app3 = new Vue({
el: '#app3',
data: {
selected: ''
}
});
效果:
當(dāng)選中某個(gè) option 時(shí)渗鬼,app3.selected 為 Object,所以 selected.number 即為 :value
定義的綁定值荧琼。
以上示例 DEMO