首页 > 语言 > JavaScript > 正文

Vue表单输入绑定的示例代码

2024-05-06 15:28:17
字体:
来源:转载
供稿:网友

基础用法

你可以用v-model指令在表单input,textarea以及select元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇,但是v-model本质上不过是语法糖。它负责监听用户的输入事件以更新数据。

v-model会忽略所有表单元素的value, checked, selected特性的初始值而总是将Vue实例的数据作为数据来源。你应该通过JavaScript在组件的data选项中声明初始值。

(1) 文本

<input v-model="message" placehoder="edit me">

(2) 多行文本

<textarea v-model="message"></textarea>

(3) 复选框

单个复选框,绑定到布尔值:

<input type="checkbox" v-model="checked">

多个复选框,绑定到同一个数组:

<div id='example-3'> <input type="checkbox" id="jack" value="Jack" v-model="checkedNames"> <label for="jack">Jack</label> <input type="checkbox" id="john" value="John" v-model="checkedNames"> <label for="john">John</label> <input type="checkbox" id="mike" value="Mike" v-model="checkedNames"> <label for="mike">Mike</label> <br> <span>Checked names: {{ checkedNames }}</span></div>new Vue({ el: '#example-3', data: {  checkedNames: [] }})

(4) 单选按钮

<div id="example-4"> <input type="radio" id="one" value="One" v-model="picked"> <label for="one">One</label> <br> <input type="radio" id="two" value="Two" v-model="picked"> <label for="two">Two</label> <br> <span>Picked: {{ picked }}</span></div>new Vue({ el: '#example-4', data: {  picked: '' }})

(5) 选择框

单选时:

<div id="example-5"> <select v-model="selected">  <option disabled value="">请选择</option>  <option>A</option>  <option>B</option>  <option>C</option> </select> <span>Selected: {{ selected }}</span></div>new Vue({ el: '...', data: {  selected: '' }})

如果 v-model 表达式的初始值未能匹配任何选项,<select> 元素将被渲染为“未选中”状态。在 iOS 中,这会使用户无法选择第一个选项。因为这样的情况下,iOS 不会触发 change 事件。因此,更推荐像上面这样提供一个值为空的禁用选项。

多选时(绑定到一个数组)

<div id="example-6"> <select v-model="selected" multiple style="width: 50px;">  <option>A</option>  <option>B</option>  <option>C</option> </select> <br> <span>Selected: {{ selected }}</span></div>new Vue({ el: '#example-6', data: {  selected: [] }})            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选