vue.js自定义组件实现v-model双向数据绑定的示例代码


Posted in Javascript onJanuary 08, 2020

我们都清楚v-model其实就是vue的一个语法糖,用于在表单控件或者组件上创建双向绑定。

//表单控件上使用v-model
<template>
 <input type="text" v-model="name" />
 <input type="checkbox" v-model="checked"/>
 <!--上面的input和下面的input实现的效果是一样的-->
 <input type="text" :value="name" @input="name=e.target.vlaue"/>
 <input type="checkBox" :checked="checked" @click=e.target.checked/>
 {{name}}
</template>
<script>
export default{
 data(){
  return {
   name:"",
   checked:false,
  }
 }
}
</script>

vue中父子组件的props通信都是单向的。父组件通过props向下传值给子组件,子组件通过$emit触发父组件中的方法。所以自定义组件是无法直接使用v-model来实现v-model双向绑定的。那么有什么办法可以实现呢?

//父组件
<template>
 <div>
  <c-input v-model="form.name"></c-input>
  <c-input v-model="form.password"></c-input>
  <!--上面的input等价于下面的input-->
 <!--<c-input :value="form.name" @input="form.name=e.target.value"/>
  <c-input :value="form.password" @input="form.password=e.target.value"/>-->
 </div>
</template>
<script>
import cInput from "./components/Input"
export default {
 components:{
  cInput
 },
 data() {
  return {
   form:{
    name:"",
    password:""
   },
   
  }
 },
}
</script>
//子组件 cInput
<template>
  <input type="text" :value="inputValue" @input="handleInput">
</template>
<script>
export default {
 props:{
  value:{
   type:String,
   default:"",
   required:true,
  }
 },
 data() {
  return {
   inputValue:this.value,
  }
 },
 methods:{
  handleInput(e){
   const value=e.target.value;
   this.inputValue=value;
   this.$emit("input",value);
  },
 }
}
</script>

根据上面的示例代码可以看出,子组件c-input上绑定了父组件form的值,在子组件中通过:value接收了这个值,然后我们在子组件中修改了这个值,并且通过$emit触发了父组件中的input事件将修改的值又赋值给了form。

综上就实现了自定义组件中的双向数据绑定!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS实现漂亮的淡蓝色滑动门效果代码
Sep 23 Javascript
jquery背景跟随鼠标滑动导航
Nov 20 Javascript
jQuery获得字体颜色16位码的方法
Feb 20 Javascript
vue.js开发环境搭建教程
May 04 Javascript
如何抽象一个Vue公共组件
Oct 17 Javascript
angularJs中ng-model-options设置数据同步的方法
Sep 30 Javascript
vue父组件触发事件改变子组件的值的方法实例详解
May 07 Javascript
node.js实现简单的压缩/解压缩功能示例
Nov 05 Javascript
js实现秒表计时器
Dec 16 Javascript
VUE实时监听元素距离顶部高度的操作
Jul 29 Javascript
javascript前端和后台进行数据交互方法示例
Aug 07 Javascript
selenium 反爬虫之跳过淘宝滑块验证功能的实现代码
Aug 27 Javascript
微信小程序实现吸顶效果
Jan 08 #Javascript
JS实现吸顶特效
Jan 08 #Javascript
vue项目中在可编辑div光标位置插入内容的实现代码
Jan 07 #Javascript
electron+vue实现div contenteditable截图功能
Jan 07 #Javascript
解决vue elementUI中table里数字、字母、中文混合排序问题
Jan 07 #Javascript
Vue程序化的事件监听器(实例方案详解)
Jan 07 #Javascript
微信小程序服务器日期格式化问题
Jan 07 #Javascript
You might like
PHP 第二节 数据类型之数组
2012/04/28 PHP
PHP使用Mysqli类库实现完美分页效果的方法
2016/04/07 PHP
yii2整合百度编辑器umeditor及umeditor图片上传问题的解决办法
2016/04/20 PHP
Prototype使用指南之string.js
2007/01/10 Javascript
用JQuery 实现AJAX加载XML并解析的脚本
2009/07/25 Javascript
jQuery的.live()和.die() 使用介绍
2011/09/10 Javascript
js实现字符串的16进制编码不加密
2014/04/25 Javascript
JavaScript必知必会(十) call apply bind的用法说明
2016/06/08 Javascript
Vue数据驱动模拟实现5
2017/01/13 Javascript
javascript实现页面滚屏效果
2017/01/17 Javascript
angularjs结合html5实现拖拽功能
2018/06/25 Javascript
vue项目首屏打开速度慢的解决方法
2019/03/31 Javascript
详解小程序input框失焦事件在提交事件前的处理
2019/05/05 Javascript
深入浅析nuxt.js基于ssh的vue通用框架
2019/05/21 Javascript
layui自定义验证,用ajax查询后台是否有重复数据,form.verify的例子
2019/09/06 Javascript
[03:24]CDEC.Y赛前采访 努力备战2016国际邀请赛中国区预选赛
2016/06/25 DOTA
[44:37]完美世界DOTA2联赛PWL S3 Forest vs access 第一场 12.11
2020/12/13 DOTA
python查找指定具有相同内容文件的方法
2015/06/28 Python
Python切片工具pillow用法示例
2018/03/30 Python
python中aioysql(异步操作MySQL)的方法
2019/04/11 Python
python的debug实用工具 pdb详解
2019/07/12 Python
python Tensor和Array对比分析
2020/01/08 Python
Django 项目通过加载不同env文件来区分不同环境
2020/02/17 Python
详解使用HTML5的classList属性操作CSS类
2017/10/13 HTML / CSS
中国领先的专业演出票务网:永乐票务
2016/08/29 全球购物
美国家用电器和电子产品商店:Abt
2016/09/06 全球购物
英国书籍、CD、DVD和游戏的第一道德零售商:Awesome Books
2020/02/22 全球购物
Conforama瑞士:家具、厨房、电器、装饰
2020/09/06 全球购物
方法名是否可以与构造器的名字相同
2012/06/04 面试题
Java的基础面试题附答案
2016/01/10 面试题
介绍一下Ruby的多线程处理
2013/02/01 面试题
建筑专业自荐信范文
2014/01/05 职场文书
遗产继承公证书
2014/04/09 职场文书
体育活动总结
2015/02/04 职场文书
在酒桌上的敬酒词
2015/08/12 职场文书
如何在python中实现ECDSA你知道吗
2021/11/23 Python