美烦资源网

专注技术文章分享,涵盖编程教程、IT 资源与前沿资讯

10《Vue 入门教程》Vue 双向绑定指令

1. 前言

本小节我们将介绍 Vue 中数据的双向绑定指令 v-modelv-model 的学习相对简单。我们可以用 v-model 指令在表单

描述是: {{ desc }}

<script src="https://unpkg.com/vue/dist/vue.js"></script> <script> var vm = new Vue({ el: '#app', data: { desc: '' }, }) </script>

"运行案例" 可查看在线运行效果

代码解释: 上述代码,我们通过 v-model 给输入框 textarea 和 desc 形成双向绑定,当 textarea 中数据发生改变时 desc 也会发生改变。同理,我们在控制台通过 vm.desc = "" 给 desc 赋值时输入框的内容也会发生改变。

3.3 单个复选框

实例演示




  
  
  
  Document


  
选项: {{ isDelivery }}
<script src="https://unpkg.com/vue/dist/vue.js"></script> <script> var vm = new Vue({ el: '#app', data: { isDelivery: false }, }) </script>

"运行案例" 可查看在线运行效果

代码解释: 上述代码,我们通过 v-model 给单个选择框 checkboxisDelivery 形成双向绑定,当 checkbox 改变选中状态时 isDelivery 也会发生改变。同理,我们在控制台通过 vm.isDelivery = trueisDelivery 赋值时 checkbox 的选中状态也会发生改变。

3.4 多个复选框

实例演示




  
  
  
  Document


  

类型: {{ types }}
<script src="https://unpkg.com/vue/dist/vue.js"></script> <script> var vm = new Vue({ el: '#app', data: { types: [] }, }) </script>

"运行案例" 可查看在线运行效果

代码解释: 上述代码,我们通过 v-model 给多个选择框 checkboxtypes 形成双向绑定,当任意 checkbox 改变选中状态时 types 也会发生改变。同理,我们在控制台通过 vm.types = []types 赋值时对应 checkbox 的选中状态也会发生改变。

3.5 单选按钮

实例演示




  
  
  
  Document


  

选择: {{ isFree }}
<script src="https://unpkg.com/vue/dist/vue.js"></script> <script> var vm = new Vue({ el: '#app', data: { isFree: '' }, }) </script>

"运行案例" 可查看在线运行效果

代码解释: 上述代码,我们通过 v-model 给单选按钮 radio 和 isFree 形成双向绑定,当 radio 改变选中状态时 isFree 也会发生改变。同理,我们在控制台通过 vm.isFree = 0 给 isFree 赋值时 radio 的选中状态也会发生改变。

3.6 下拉选择框

实例演示




  
  
  
  Document


  
选项: {{ company }}
<script src="https://unpkg.com/vue/dist/vue.js"></script> <script> var vm = new Vue({ el: '#app', data: { company: '' }, }) </script>

"运行案例" 可查看在线运行效果

代码解释: 上述代码,我们通过 v-model 给选择框 select 和 company 形成双向绑定,当 select 改变选项时 company 也会发生改变。同理,我们在控制台通过 vm.company = 0 给 company 赋值时 select 的选中项也会发生改变。

4. 值绑定

对于单选按钮、复选框及选择框的选项,v-model 绑定的值通常是静态字符串 (对于复选框也可以是布尔值):









但是有时我们可能想把值绑定到 Vue 实例的一个动态属性上,这时可以用 v-bind 实现,并且这个属性的值可以不是字符串。

4.1 复选框绑定值


代码解释: 上述代码中,我们通过 true-value 和 false-value 给 复选框指定来选中和非选中的值,当选中时 vm.isDelivery === 'yes',当没有选中时 vm.isDelivery === 'no'

4.2 单选按钮绑定值


// 当选中时
vm.pick === vm.a

代码解释: 上述代码中,我们通过 v-bind:value 给 randio 指定选中的值,当 radio 选中时 vm.pick === vm.a

4.3 选择框选项绑定值


代码解释: 上述代码中,我们通过 v-bind:value 给 option 指定 value 值,当 该 option 选中时 vm.selected 的值为 { number: 123 }

5. 修饰符

5.1 .lazy

在默认情况下,v-model 在每次 input 事件触发后将输入框的值与数据进行同步 (除了上述输入法组合文字时)。你可以添加 lazy 修饰符,从而转变为使用 change 事件进行同步:



5.2 .number

如果想自动将用户的输入值转为数值类型,可以给 v-model 添加 number 修饰符:


5.3 .trim

如果要自动过滤用户输入的首尾空白字符,可以给 v-model 添加 trim 修饰符:


6. 小结

本小节我们介绍了 Vue 数据双向绑定 v-model 的使用,主要包括以下知识点:

  • 使用 v-model 对 input、textarea、select 等表单项进行数据绑定;
  • 使用 v-bind:value 给表单项的值进行绑定;
  • v-model 修饰符的使用。
控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言