Vue之彻底理解自定义组件的v-model

最近在学习vue,今天看到自定义事件的表单输入组件,纠结了一会会然后恍然大悟...官方教程写得不是很详细,所以我决定总结一下。

v-model语法糖

v-model实现了表单输入的双向绑定,我们一般是这么写的:

1 <div id="app">
2     <input v-model="price">
3 </div>
1 new Vue({
2     el: ‘#app‘,
3     data: {
4          price: ‘‘
5     }
6 });

通过该语句实现price变量与输入值双向绑定

实际上v-model只是一个语法糖,真正的实现是这样的:

1 <input type="text"       :value="price"       @input="price=$event.target.value">

以上代码分几个步骤:

  1. 将输入框的值绑定到price变量上,这个是单向绑定,意味着改变price变量的值可以改变input的value,但是改变value不能改变price
  2. 监听input事件(input输入框都有该事件,当输入内容时自动触发该事件),当输入框输入内容就单向改变price的值

这样就实现了双向绑定。

自定义表单输入组件

我们平时写input可以不像上面那么复杂,直接用v-model就行了,但是既然我们研究这个语法糖那肯定是有别的用处,比如说自定义表单输入框组件。

1 <div id="app">
2      <input-price v-model="price"></input-price>
3 </div>
1 Vue.component(‘input-price‘, {
2     template: ‘<input type=‘text‘>‘
3 });
4 new Vue({
5     el: ‘#app‘,
6     data: {
7          price: ‘‘
8     }
9 });

上面的<input-price>是我们自定义的表单输入组件,我们能直接用v-model实现双向绑定吗?如果你觉得可以那你就是Too young了~

首先根据我们的v-model语法糖来看

  1. 我们的子组件(input-price)的value需要绑定一个从父组件传来的值,通过子组件的props接收
  2. 在子组件上有新的输入时需要触发父组件的input事件,并将新的值作为参数传递给父组件
1 <div id="app">
2     <!-- <price-input v-model="price"></price-input> -->
3
4      <!-- 手动实现了v-model双向绑定 -->
5      <!-- 3、父组件的input事件被触发,将传来的值赋给父组件的变量price -->
6      <!-- 4、父组件value的值绑定到price -->
7      <price-input :value="price" @input="onInput"></price-input>
8      <p>{{price}}</p>
9 </div>
 1 Vue.component(‘price-input‘, {
 2     // 5、将父组件的value值通过props传递给子组件
 3     // 1、当有数据输入时触发了该组件的input事件
 4     template: ‘<input :value="value" @input="updateVal($event.target.value)" type="text">‘,
 5     props: ["value"],
 6     methods: {
 7          updateVal: function(val) {
 8             // 2、手动触发父组件的input事件并将值传给父组件
 9             this.$emit(‘input‘, val);
10          }
11      }
12 });
13 var app = new Vue({
14      el: ‘#app‘,
15      data: {
16          price: ‘‘
17      },
18      methods: {
19           onInput: function(val) {
20                this.price = val;
21           }
22       }
23  });

这里备注了几个步骤:

  1. 当有数据输入时触发了该组件的input事件
  2. 手动触发父组件的input事件并将值传给父组件
  3. 父组件的input事件被触发,将传来的值赋给父组件的变量price,实现输入框value到父元素的price的单向绑定
  4. 父组件value的值绑定到price 
  5. 将父组件的value值通过props传递给子组件,实现了父组件的price到子组件value的单向绑定

小小的总结一下:

  • v-bind只能实现单向绑定
  • v-model(v-bind+触发的input事件)实现双向绑定

如果大家有什么意见或建议希望大家在评论区多多交流,谢谢。

时间: 2024-09-29 13:33:00

Vue之彻底理解自定义组件的v-model的相关文章

关于vue如何创建一个自定义组件(这是项目中经常得用的)

1. 首先作大米饭我们得有米吧 要不 巧妇难为无米之炊啊  因此先买好我们自己的大米也就是创建组件文件,这里我假设要创建一个自己loading效果组件 那么我们就先创建 loading.vue 里面的代码根据vue template相关规则写就可以 这里就不在赘述了 我只写一个最最简单的例子 2.ok了 米就这么愉快的买好了 那么有了米我们现在只需要把他放在锅里!那么这个锅是谁呢!好吧我们自己来背这个锅,我们创建一个相关的.js文件 通常组件都是一个功能自己一个文件夹那么每个组件都应该有自己独立

Vue.extend提供自定义组件的构造器

Vue.extend 返回的是一个“扩展实例构造器”,也就是预设了部分选项的Vue实例构造器.经常服务于Vue.component用来生成组件,可以简单理解为当在模板中遇到该组件名称作为标签的自定义元素时,会自动调用“扩展实例构造器”来生产组件实例,并挂载到自定义元素上. 自定义无参数标签 我们想象一个需求,需求是这样的,要在博客页面多处显示作者的网名,并在网名上直接有链接地址.我们希望在html中只需要写<message></message> ,这和自定义组件很像,但是他没有传递

vue.js2.0 自定义组件初体验

理解 组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素, Vue.js 的编译器为它添加特殊功能.在有些情况下,组件也可以是原生 HTML 元素的形式,以 is 特性扩展. 使用组件 创建单文件组件 <template> </template> <script> export default { }; </script> <style lang="st

自定义组件&lt;六&gt;:深入理解ViewGroup

自定义组件ViewGroup深入理解 有前几张环节可以看出来: 自定义组件的测量过程和绘制过程想弄懂并不是那么的容易. 接下里我就仔细给大家来讲一下 测量过程-:onMeasure()以及 布局过程:onLayout() 一个Viewgroup基本的继承类格式如下: 1 import android.content.Context;  2 import android.view.ViewGroup;  3   4 public class MyViewGroup extends ViewGrou

vue框架之自定义组件中使用v-model

通常 vue在html常见表单空间支持v-model双向绑定例如 1 <input v-model="message" placeholder="edit me"> 2 <p>Message is: {{ message }}</p> 1,当我们自定义组件时如何使用v-model? 答:代码实例如下 2 我们在自定义组件中使用v-model的目的是什么? 答:自定义模板上定义v-mode目的是向外传递值,也就是向他的父组件传递值,

[转] vue自定义组件中的v-model简单解释

在使用iview框架的时候,经常会看到组件用v-model双向绑定数据,与传统步骤父组件通过props传值子组件,子组件发送$emit来修改值相比,这种方式避免操作子组件的同时再操作父组件,显得子组件的封装效果更好.所以,个人认为,我们自己封装组件也应该有这样的思维,父组件通过slot或者props传值,由子组件完成一些效果,再抛出必要的事件让父组件接受,这样组件的可复用性就很强,有利于多次使用. v-model指令是什么? 刚刚提到,iview通过v-model双向绑定数据,所以首先我们要明白

Vue结合原生js实现自定义组件自动生成

就目前三大前端主流数据驱动框架(vue,ng,react)而言,均具有创建自定义组件的api,但都是必须先做到事先写好挂载点,这个挂载点可以是原有静态元素标签也可以是自定义模板:对于多种组件通过同一数据流生成的,如果事先在页面上写好挂载点(mounted),然后通过dom操作去动态添加,会遇到类似这样一条错误提示信息:Failed to execute 'appendChild' on 'Node': parameter 1 is not of type 'Node'.(…).这又是为何呢,下一

vue中自定义组件(插件)

vue中自定义组件(插件) 原创 2017年01月04日 22:46:43 标签: 插件 在vue项目中,可以自定义组件像vue-resource一样使用Vue.use()方法来使用,具体实现方法: 1.首先建一个自定义组件的文件夹,比如叫loading,里面有一个index.js,还有一个自定义组件loading.vue,在这个loading.vue里面就是这个组件的具体的内容,比如: <template> <div> loading.............. </div

vue的自定义组件和组件传值

<div id="app"> <div>{{pmessage}}</div> //父组件 <child :message="pmessage"></child>//打开一个通道 绑定message </div> Vue.component('child',{ props:['message'], //使用props 来接收信息 template:'<h1>{{message}}<