vue 2.0组件与v-model详解


Posted in Javascript onMarch 27, 2017

前言

大家可能乍一看这个标题,可能会有疑问:v-model和组件也能扯到一起?在打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章:

情景【Situation】:

编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能通过this.$children.xxx取值然后付给dataA,

而是父组件可以直接this.dataA就可以取到当前子组件最新值。

任务【Task】:

实现在父组件直接this.dataA就可以取到当前子组件最新值。

行动【Action】:

首先要了解v-model这个指令,许多认真阅读过完整vue文档的同学可能已经知道了关于v-model。

v-model官方给出的说发是:这其实是一个简写的形式,v-model实际执行的是下面的绑定:

<input type="text" v-bind:value="dataA" v-on:input="dataA = $event.target.value" />

v-model是动态绑定值到value,然后监听input的inpit事件获取值后赋给dataA的一个过程。

在说一下input的value属性,在组件内部要定义一个value的props属性,以便能够动态绑定上父组件传过来的值;

组件内部还要做一件事情:

动态计算(获取和设置)currentValue的值,用到了vue的对象的get和set函数;

讲到这里,我们就可以解决上面的问题了;

首先定义一个通用输入组件:

Vue.component('my-component',{
 template:'<div><input type="text" type="text" v-model="currentValue"/></div>',
 data:function(){
 return {
  // 双向绑定值-必须
  currentValue:this.value
 }
 },
 props:['value'],// 设置value为props属性-必须
 computed:{
 currentValue: {
  // 动态计算currentValue的值
  get:function() {
  return this.value;
  },
  set:function(val) {
  this.$emit('input', val);
  }
 }
 }
})

在Html里绑定到vue实例的一个字段上;

<div id="demo_01">
 <my-component v-for="(val,key) in postData" v-model="postData[key]"></my-component>
 <button @click="showValue">打印对象值</button>
 </div>

实例里写一个方法

打印一下我们绑定的值;

var demo_01 = new Vue({
 el:'#demo_01',
 data:{
 postData:{
  name:'李雷',
  age:'80',
  describ:'这是一个传奇的人物'
 }
 },
 methods:{
 showValue:function(){
  console.log(this.postData)
 }
 }
});

是不是以后就不用繁琐冗长的this.$children.xxx取值方式了?

结果【Result】:

提供了有效的解决了关于输入类组件取值方案,并且已经部署实施。

总结

以上就是关于vue2.0 组件和v-model的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的帮助。

Javascript 相关文章推荐
再次更新!MSClass (Class Of Marquee Scroll通用不间断滚动JS封装类 Ver 1.6)
Feb 05 Javascript
Javascript中产生固定结果的函数优化技巧
Jan 16 Javascript
jquery ready(fn)事件使用介绍
Aug 21 Javascript
JS将数字转换成三位逗号分隔的样式(示例代码)
Feb 19 Javascript
jQuery实现简单的日期输入格式化控件
Mar 12 Javascript
JavaScript中数据结构与算法(三):链表
Jun 19 Javascript
JavaScript中调用函数的4种方式代码实例
Jul 08 Javascript
Vue.js实现拖放效果的实例
Sep 30 Javascript
Javascript 跨域知识详细介绍
Oct 30 Javascript
vue-cli项目使用mock数据的方法(借助express)
Apr 15 Javascript
jquery ajax 请求小技巧实例分析
Nov 11 jQuery
JS对象属性的检测与获取操作实例分析
Mar 17 Javascript
JavaScript无缝滚动效果的实例代码
Mar 27 #Javascript
JS数组搜索之折半搜索实现方法分析
Mar 27 #Javascript
javascript实现下雨效果
Mar 27 #Javascript
HTML的select控件美化
Mar 27 #Javascript
JS实现的点击表头排序功能示例
Mar 27 #Javascript
深入理解AngularJS中的ng-bind-html指令
Mar 27 #Javascript
vue2.0实战之基础入门(1)
Mar 27 #Javascript
You might like
discuz目录文件资料汇总
2014/12/30 PHP
PHP将字符串首字母大小写转换的实例
2017/01/21 PHP
PHP数字前补0的自带函数sprintf 和number_format的用法(详解)
2017/02/06 PHP
thinkPHP多表查询及分页功能实现方法示例
2017/07/03 PHP
thinkPHP3.2.2框架行为扩展及demo示例
2018/06/19 PHP
laravel5.6中的外键约束示例
2019/10/23 PHP
javascript学习随笔(使用window和frame)的技巧
2007/03/08 Javascript
jquery remove方法应用详解
2012/11/22 Javascript
Javascript自定义排序 node运行 实例
2013/06/05 Javascript
jquery属性过滤选择器使用示例
2013/06/18 Javascript
JS对话框_JS模态对话框showModalDialog用法总结
2014/01/11 Javascript
BootStrap响应式导航条实例介绍
2016/05/06 Javascript
js无提示关闭浏览器窗口的两种方法分析
2016/11/06 Javascript
javascript实现秒表计时器的制作方法
2017/02/16 Javascript
详解nodeJS之二进制buffer对象
2017/06/03 NodeJs
AngularJS 支付倒计时功能实现思路
2017/06/05 Javascript
javascript实现QQ空间相册展示源码
2017/12/12 Javascript
Vue中的$set的使用实例代码
2018/10/08 Javascript
详解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on
2018/10/12 Javascript
vue-路由精讲 二级路由和三级路由的作用
2020/08/06 Javascript
python基础教程之字典操作详解
2014/03/25 Python
Python中实现结构相似的函数调用方法
2015/03/10 Python
Python中实现三目运算的方法
2015/06/21 Python
Python调用系统底层API播放wav文件的方法
2017/08/11 Python
python中将函数赋值给变量时需要注意的一些问题
2017/08/18 Python
对numpy 数组和矩阵的乘法的进一步理解
2018/04/04 Python
python使用tkinter库实现五子棋游戏
2019/06/18 Python
Python threading的使用方法解析
2019/08/28 Python
物理研修随笔感言
2014/02/14 职场文书
2015年新学期寄语
2015/02/26 职场文书
2016年春季开学典礼新闻稿
2015/11/25 职场文书
2016北大自主招生自荐信模板
2016/01/28 职场文书
《日月潭》教学反思
2016/02/20 职场文书
一文搞懂redux在react中的初步用法
2021/06/09 Javascript
CSS文本阴影 text-shadow 悬停效果详解
2022/05/25 HTML / CSS
git stash(储藏)的用法总结
2022/06/25 Servers