vue项目中v-model父子组件通信的实现详解


Posted in Javascript onDecember 10, 2017

前言

我们在vue项目中,经常有这样的需求,父组件绑定v-model,子组件输入更改父组件v-model绑定的数值。很多朋友对这种操作不是很清楚,这需要对v-model有比较深入的了解,今天谈谈v-model。

vue的双向数据绑定

v-model这个指令只能用在<input>, <select>,<textarea>这些表单元素上,所谓双向绑定,指的就是我们在js中的vue实例中的data与其渲染的dom元素上的内容保持一致,两者无论谁被改变,另一方也会相应的更新为相同的数据。

这个问题在很多前端面试中,会提及。面试官问你,vue的双向数据绑定原理是什么?当然,这个也是耳熟能详的问题,百度随便一搜索,到处都能找到答案。

一般都会搜索到,是用Object.defineProperty( ) ,来监听数据get和set,来实现数据劫持的。

假如对Object.defineProperty( )不是很了解,可以点击上面链接,看看其语法!

举个简单的例子:

var blog = {
 name: 'haorooms博客'
};
console.log(blog.name); // haorooms博客

如果想要在执行console.log(blog.name)的同时,直接给haorooms博客加个书名号,那要怎么处理呢?或者说要通过什么监听对象 blog的属性值。这时候Object.defineProperty( )就派上用场了,代码如下:

var blog= {}
var name = '';
Object.defineProperty(blog, 'name', {
 set: function (value) {
 name = value;
 console.log('欢迎来到' + value);
 },
 get: function () {
 return '《' + name + '》'
 }
})
blog.name = 'haorooms博客'; // 欢迎来到haorooms博客
console.log(blog.name); // 《haorooms博客》

上面代码执行一下,可以查看效果!

关于 vue的双向数据绑定,具体如何实现的?网上也有很多实现的代码,这里就不多累赘了!

v-model 的使用

上面开了一个小差,讲了那么多,其实就是为了说明Vue 是单项数据流,v-model 只是语法糖而已。

<input v-model="haorooms" />
<input v-bind:value="haorooms" v-on:input="haorooms= $event.target.value" />

第一行的代码其实只是第二行的语法糖。然后第二行代码还能简写成这样:

<input :value="haorooms" @input="haorooms= $event.target.value" />

也就是说,

<input v-model="haorooms" />

也可以写成

<input :value="haorooms" @input="haorooms= $event.target.value" />

v-model在组件上的使用

回到我们一开始的疑问了?vue中v-model如何进行父子组件的通信?如何在组件中使用呢?假如你理解了我上面的例子,那么,我们就可以很简单的在组件中使用v-model了。

父组件代码如下:

<template>
 <div id="demo">
 <test-model v-model="haorooms"></test-model>
 <span>{{haorooms}}</span>
</div>
</template>
<script>
  import testModel from 'src/components/testModel'
  export default {
   data(){
      return{
         haorooms: "haorooms"
      }
    },
    components: {
      testModel,
    }
  }
</script>
<style lang="scss" scoped>
</style>

子组件代码如下:

<template>
<span>
   <input
    ref="input"
    :value="value"
    @input="$emit('balabala', $event.target.value)"
   >
  </span>
</template>
<script>
  export default {
    data(){
      return{
      }
    },
    props: ["value"],
    model: {
      prop: 'value',
      event: 'balabala'
    }
  }
</script>
<style lang="scss" scoped>
</style>

我们可以通过上面代码,子组件修改父组件v-model绑定的值!

实现截图如下:

vue项目中v-model父子组件通信的实现详解

v-model 的缺点和解决办法

在创建类似复选框或者单选框的常见组件时,v-model就不好用了。

<input type="checkbox" v-model="haorooms" />

我们可以用如下方式解决:

<input type="checkbox" :checked="status" @change="status = $event.target.checked" />

父组件可以如下写:

<my-checkbox v-model="haorooms"></my-checkbox>

子组件:

<input 
        type="checkbox"
        <!--这里就不用 input 了,而是 balabala-->
        @change="$emit('balabala', $event.target.checked)"
        :checked="value"
       />
 export default {
    data(){
      return{
      }
    },
    props: ['checked'], //这里就不用 value 了,而是 checked
   model: {
     prop: 'checked',
     event: 'balabala'
    },
  }

关于vue的v-model就写到这里。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
jQuery设置和获取HTML、文本和值示例
Jul 08 Javascript
jQuery中用dom操作替代正则表达式
Dec 29 Javascript
javascript基于prototype实现类似OOP继承的方法
Dec 16 Javascript
javascript html实现网页版日历代码
Mar 08 Javascript
JS 拦截全局ajax请求实例解析
Nov 29 Javascript
jQuery实现的分页功能示例
Jan 22 Javascript
vue组件 $children,$refs,$parent的使用详解
Jul 31 Javascript
基于js原生和ajax的get和post方法以及jsonp的原生写法实例
Oct 16 Javascript
Node.js静态服务器的实现方法
Feb 28 Javascript
JavaScript实现图片懒加载的方法分析
Jul 05 Javascript
JavaScript设计模式之观察者模式实例详解
Jan 16 Javascript
使用Vue实现调用接口加载页面初始数据
Oct 28 Javascript
Angular项目从新建、打包到nginx部署全过程记录
Dec 09 #Javascript
利用ES6实现单例模式及其应用详解
Dec 09 #Javascript
利用node.js如何创建子进程详解
Dec 09 #Javascript
微信小程序使用slider设置数据值及switch开关组件功能【附源码下载】
Dec 09 #Javascript
微信小程序实现action-sheet弹出底部菜单功能【附源码下载】
Dec 09 #Javascript
微信小程序使用toast消息对话框提示用户忘记输入用户名或密码功能【附源码下载】
Dec 09 #Javascript
微信小程序loading组件显示载入动画用法示例【附源码下载】
Dec 09 #Javascript
You might like
收音机发烧友应当熟知的100条知识
2021/03/02 无线电
php 什么是PEAR?(第二篇)
2009/03/19 PHP
细谈php中SQL注入攻击与XSS攻击
2012/06/10 PHP
关于二级目录拖拽排序的实现(源码示例下载)
2013/04/26 PHP
Windows下编译PHP5.4和xdebug全记录
2015/04/03 PHP
制作高质量的JQuery Plugin 插件的方法
2010/04/20 Javascript
jquery对dom的操作常用方法整理
2013/06/25 Javascript
关于JavaScript中name的意义冲突示例介绍
2014/05/29 Javascript
jQuery中on()方法用法实例
2015/01/19 Javascript
简单谈谈javascript Date类型
2015/09/06 Javascript
jquery 实现输入邮箱时自动补全下拉提示功能
2015/10/04 Javascript
JavaScript来实现打开链接页面的简单实例
2016/06/02 Javascript
基于JS实现导航条之调用网页助手小精灵的方法
2016/06/17 Javascript
Vue.js实现分页查询功能
2020/11/15 Javascript
swiper.js插件实现pc端文本上下滑动功能示例
2018/12/03 Javascript
Vue简单实现原理详解
2020/05/07 Javascript
python实现马耳可夫链算法实例分析
2015/05/20 Python
python django 增删改查操作 数据库Mysql
2017/07/27 Python
Python实现JSON反序列化类对象的示例
2018/01/31 Python
使用Python读取安卓手机的屏幕分辨率方法
2018/03/31 Python
Flask框架Flask-Principal基本用法实例分析
2018/07/23 Python
django+xadmin+djcelery实现后台管理定时任务
2018/08/14 Python
Python用Try语句捕获异常的实例方法
2019/06/26 Python
python 判断字符串中是否含有汉字或非汉字的实例
2019/07/15 Python
Django  ORM 练习题及答案
2019/07/19 Python
python 第三方库paramiko的常用方式
2021/02/20 Python
比利时的在线灯具店:Lampen24.be
2019/07/01 全球购物
会计自我鉴定
2013/11/02 职场文书
工程质量承诺书范文
2014/03/27 职场文书
员工考核评语大全
2014/04/26 职场文书
领导班子作风建设年个人整改措施
2014/09/29 职场文书
公司股份转让协议书范本
2015/01/28 职场文书
实习感想范文
2015/08/10 职场文书
数学复习课教学反思
2016/02/18 职场文书
2016年“我们的节日·中秋节”活动总结
2016/04/05 职场文书
PyTorch 如何设置随机数种子使结果可复现
2021/05/12 Python