Vue.js 中的 v-model 指令及绑定表单元素的方法


Posted in Javascript onDecember 03, 2018

我们可以使用 Vue.js 中的 v-model 指令来完成表单数据的双向绑定。

1 基础用法

1.1 文本输入框(text)

这里演示了在文本输入框上输入的内容,会实时映射到绑定的数据上。

html:

<div id="app">
 <input type="text" v-model="content" placeholder="请输入">
 <p>输入框:{{content}}</p>
</div>

js:

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

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

1.2 大文本输入框(textarea)

绑定方法与文本输入框相同。

html:

<div id="app2">
 <textarea v-model="content" placeholder="请输入"></textarea>
 <p>内容:</p>
 <p style="white-space: pre">{{content}}</p>
</div>

js:

var app2 = new Vue({
 el: '#app2',
 data: {
  content: ''
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

这里对展示的内容所对应的 <p> 元素加了 white-space: pre 样式,这样内容即使带有回车符也会保留。

--------------------------------------------------------------------------------

注意:表单控件所显示的值只依赖于所绑定的数据,所以即便设置了表单控件中的 value值,也不会起作用哦。同理,<textarea>xxx</textarea>之间的值也无效。

之前的示例我们可以发现,使用中文输入法时,只有确定选中的词语,才会被如果 Vue.js 所更新。如果希望输入的内容实时更新,那么可以使用 @input。

html:

<div id="app3">
 <textarea @input="inputHandler" placeholder="请输入"></textarea>
 <p>内容:</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 定义的函数不带参数,Vue.js 也会在定义的函数(示例中的 inputHandler)中传入 event 原生事件对象。

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

1.3 单选框

单选框一般都有多个条件可供选择,既然是单选框,自然希望实现互斥效果,我们可以使用 v-model 指令配合单选框的 value 来实现。

html:

<div id="app4">
 <input id="radio1" type="radio" v-model="checked" value="文学">
 <label for="radio1">文学</label>
 <input id="radio2" type="radio" v-model="checked" value="艺术">
 <label for="radio2">艺术</label>
 <input id="radio3" type="radio" v-model="checked" value="经济">
 <label for="radio3">经济</label>
 <br>
 <p>选择了:{{checked}}</p>
</div>

js:

var app4 = new Vue({
 el: '#app4',
 data: {
  checked: '文学'
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

1.4 复选框

复选框的绑定方式与单选框相同,只不过复选框所对应的数据类型是数组罢了。

html:

<div id="app5">
 <input id="checkbox1" type="checkbox" v-model="checked" value="文学">
 <label for="checkbox1">文学</label>
 <input id="checkbox2" type="checkbox" v-model="checked" value="艺术">
 <label for="checkbox2">艺术</label>
 <input id="checkbox3" type="checkbox" v-model="checked" value="经济">
 <label for="checkbox3">经济</label>
 <br>
 <p>选择了:{{checked}}</p>
</div>

js:

var app5= new Vue({
 el: '#app5',
 data: {
  checked: ['文学','艺术']
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

1.5 下拉选择框

1.5.1 单选

html:

<div id="app6">
 <select v-model="selected">
  <option value="1">文学</option>
  <option value="2">艺术</option>
  <option>经济</option>
 </select>
 <br>
 <p>选择了:{{selected}}</p>
</div>

js:

var app6 = new Vue({
 el: '#app6',
 data: {
  selected: '1'
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

可以看出,如果 <option> 含有 value 值,则会先匹配该值;如果没有,则匹配 <option> 中的 text 值(比如示例中的 <option>经济</option>)。

1.5.2 多选

为 <select> 标签添加 multiple 属性,即可实现多选。

html:

<div id="app7">
 <select v-model="selected" multiple>
  <option value="1">文学</option>
  <option value="2">艺术</option>
  <option>经济</option>
 </select>
 <br>
 <p>选择了:{{selected}}</p>
</div>

Vue.js 中的 v-model 指令及绑定表单元素的方法

在实际应用场景,<select> 标签中的 <opinion> 一般是通过 v-for 指令动态输出的,其中每一项的 value 或 text 都可以使用 v-bind 动态输出的。

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: '文学', value: '1'},
   {text: '艺术', value: '2'}
  ]
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

--------------------------------------------------------------------------------

因为 select 标签的呈现样式依赖于浏览器,所以在实际业务场景中,我们更多的是使用 div 来模拟 select 标签的列表功能,而这可以通过使用 Vue.js 自定义组件的方式来实现一个通用的下拉选择组件。

以上示例 DEMO

2 绑定动态变量

之前所说的示例,v-model 绑定的都是静态变量。我们可以使用 v-bind 来绑定动态变量。

2.1 单选框

html:

<div id="app">
 <input id="radio1" type="radio" v-model="picked" :value="value">
 <label for="radio1">文学</label>
 <input id="radio2" type="radio" v-model="picked" :value="value2">
 <label for="radio2">艺术</label>
 <input id="radio3" type="radio" v-model="picked" :value="value3">
 <label for="radio3">经济</label>
 <br>
 <p>{{picked}}</p>
 <p>{{value}},{{value2}},{{value3}}</p>
</div>

js:

var app = new Vue({
 el: '#app',
 data: {
  picked: false,
  value: '文学',
  value2: '艺术',
  value3: '经济',
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

示例中定义的单选框默认值为 picked 所定义的 false。当选中某个单选框时,则动态绑定在 :value 中定义的变量。

2.2 复选框

html:

<div id="app2">
 <input id="checkbox" type="checkbox" v-model="checked" :true-value="value1" :false-value="value2">
 <label for="checkbox">开关</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: ''
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

复选框的默认值绑定的是 v-model 定义的变量,而勾选与取消勾选所绑定的值,则分别由 :true-value 与 false-value 来实现动态绑定。

2.3 下拉选择框

html:

<div id="app3">
 <select v-model="selected">
  <option :value="{number:1}">文学</option>
  <option :value="{number:2}">艺术</option>
 </select>
 <br>
 <p>选择了:{{selected.number}}</p>
</div>

js:

var app3 = new Vue({
 el: '#app3',
 data: {
  selected: ''
 }
});

效果:

Vue.js 中的 v-model 指令及绑定表单元素的方法

当选中某个 option 时,app3.selected 为 Object,所以 selected.number 即为 :value 定义的绑定值。

以上示例 DEMO

Javascript 相关文章推荐
使用JQUERY进行后台页面布局控制DIV实现左右式
Jan 07 Javascript
jQuery之DOM对象和jQuery对象的转换与区别分析
Jan 08 Javascript
JavaScript原生对象之Date对象的属性和方法详解
Mar 13 Javascript
javascript倒计时效果实现
Nov 12 Javascript
JavaScript代码因逗号不规范导致IE不兼容的问题
Feb 25 Javascript
JavaScript事件代理和委托详解
Apr 08 Javascript
JS简单实现自定义右键菜单实例
May 31 Javascript
EasyUI Tree树组件无限循环的解决方法
Sep 27 Javascript
JS运动改变单物体透明度的方法分析
Jan 23 Javascript
JS代码实现电脑配置检测功能
Mar 21 Javascript
在Vue项目中使用jsencrypt.js对数据进行加密传输的方法
Apr 17 Javascript
vue vant Area组件使用详解
Dec 09 Javascript
ng-zorro-antd 入门初体验
Dec 03 #Javascript
如何使用 vue + d3 画一棵树
Dec 03 #Javascript
Vue.js中 v-model 指令的修饰符详解
Dec 03 #Javascript
浅谈ng-zorro使用心得
Dec 03 #Javascript
JS跨域请求的问题解析
Dec 03 #Javascript
VueJS 组件参数名命名与组件属性转化问题
Dec 03 #Javascript
Vue.Draggable拖拽功能的配置使用方法
Jul 29 #Javascript
You might like
PHP执行zip与rar解压缩方法实现代码
2010/12/05 PHP
PHP多线程批量采集下载美女图片的实现代码(续)
2013/06/03 PHP
简单介绍PHP的责任链编程模式
2015/08/11 PHP
Linux系统下PHP-FPM的安装和配置教程
2015/08/17 PHP
php 基础函数
2017/02/10 PHP
PHP连接sftp并下载文件的方法教程
2018/08/26 PHP
js滚动条回到顶部的代码
2011/12/06 Javascript
jQuery侧边栏随窗口滚动实现方法
2013/03/04 Javascript
jquery实现div拖拽宽度示例代码
2013/07/31 Javascript
验证码在IE中不刷新而谷歌等浏览器正常的解决方案
2014/03/18 Javascript
js兼容pc端浏览器并有多种弹出小提示的手机端浮层控件实例
2015/04/29 Javascript
jQuery基于ajax()使用serialize()提交form数据的方法
2015/12/08 Javascript
JavaScript组件开发完整示例
2015/12/15 Javascript
javascript单页面手势滑屏切换原理详解
2016/03/21 Javascript
Bootstrap项目实战之子栏目资讯内容
2016/04/25 Javascript
AngularJS动态生成div的ID源码解析
2016/08/29 Javascript
jquery移除了live()、die(),新版事件绑定on()、off()的方法
2016/10/26 Javascript
bootstrapvalidator之API学习教程
2017/06/29 Javascript
使用JS组件实现带ToolTip验证框的实例代码
2017/08/23 Javascript
Vue如何实现响应式系统
2018/07/11 Javascript
vue计算属性computed的使用方法示例
2019/03/13 Javascript
微信小程序点击按钮动态切换input的disabled禁用/启用状态功能
2020/03/07 Javascript
[02:51]2014DOTA2国际邀请赛 IG战队官方纪录片
2014/07/21 DOTA
Python基于回溯法子集树模板解决野人与传教士问题示例
2017/09/11 Python
如何使用django的MTV开发模式返回一个网页
2019/07/22 Python
浅析Python语言自带的数据结构有哪些
2019/08/27 Python
Visual Studio Code搭建django项目的方法步骤
2020/09/17 Python
聊聊python在linux下与windows下导入模块的区别说明
2021/03/03 Python
Stuart Weitzman美国官网:美国奢华鞋履品牌
2016/08/18 全球购物
新英格兰最大的特色礼品连锁店:The Paper Store
2018/07/23 全球购物
e路東瀛(JAPANiCAN)香港:日本旅游、日本酒店和温泉旅馆预订
2018/11/21 全球购物
王力宏牛津大学演讲稿
2014/05/22 职场文书
就业协议书
2014/09/12 职场文书
党支部书记四风问题整改措施
2014/09/24 职场文书
2014年学校安全工作总结
2014/11/13 职场文书
Oracle 区块链表创建过程详解
2021/05/15 Oracle