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 相关文章推荐
Javascript-Mozilla和IE中的一个函数直接量的问题
Jan 09 Javascript
javascript 二进制运算技巧解析
Nov 27 Javascript
js字符串日期yyyy-MM-dd转化为date示例代码
Mar 06 Javascript
javascript 使用for循环时该注意的问题-附问题总结
Aug 19 Javascript
利用Jquery队列实现根据输入数量显示的动画
Sep 01 Javascript
Bootstrap学习笔记之环境配置(1)
Dec 07 Javascript
js获取浏览器和屏幕的各种宽度高度
Feb 22 Javascript
深入浅析JSONAPI在PHP中的应用
Dec 24 Javascript
在vue-cli项目中使用bootstrap的方法示例
Apr 21 Javascript
Vue.js最佳实践(五招助你成为vuejs大师)
May 04 Javascript
微信小程序自定义tab实现多层tab嵌套功能
Jun 15 Javascript
动态实现element ui的el-table某列数据不同样式的示例
Jan 22 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
windows下升级PHP到5.3.3的过程及注意事项
2010/10/12 PHP
php的memcached客户端memcached
2011/06/14 PHP
php导入导出excel实例
2013/10/25 PHP
Linux下PHP安装mcrypt扩展模块笔记
2014/09/10 PHP
PHP未登录自动跳转到登录页面
2016/12/21 PHP
全面解析PHP面向对象的三大特征
2017/06/10 PHP
关于js获取radio和select的属性并控制的代码
2011/05/12 Javascript
JavaScript 高级篇之函数 (四)
2012/04/07 Javascript
JS+CSS实现一个气泡提示框
2013/08/18 Javascript
在JavaScript中实现类的方式探讨
2013/08/28 Javascript
举例详解AngularJS中ngShow和ngHide的使用方法
2015/06/19 Javascript
jQuery结合AJAX之在页面滚动时从服务器加载数据
2015/06/30 Javascript
最简单的JavaScript图片轮播代码(两种方法)
2015/12/18 Javascript
js实现图片上传并正常显示
2015/12/19 Javascript
实用又漂亮的BootstrapValidator表单验证插件
2016/05/30 Javascript
解决VUEX刷新的时候出现数据消失
2017/07/03 Javascript
vue2.x 父组件监听子组件事件并传回信息的方法
2017/07/17 Javascript
解决vue项目nginx部署到非根目录下刷新空白的问题
2018/09/27 Javascript
vuejs简单验证码功能完整示例
2019/01/08 Javascript
在Python中操作时间之tzset()方法的使用教程
2015/05/22 Python
关于Django显示时间你应该知道的一些问题
2017/12/25 Python
为什么Python中没有&quot;a++&quot;这种写法
2018/11/27 Python
python3+selenium实现qq邮箱登陆并发送邮件功能
2019/01/23 Python
CSS3 3D制作实战案例分析
2016/09/18 HTML / CSS
利用CSS3的transform做的动态时钟效果
2011/09/21 HTML / CSS
html5 学习简单的拾色器
2010/09/03 HTML / CSS
移动端开发HTML5页面点击按钮后出现闪烁或黑色背景的解决办法
2018/09/19 HTML / CSS
国际贸易专业推荐信
2013/11/15 职场文书
项目合作协议书范本
2014/04/16 职场文书
植树节活动总结
2014/04/30 职场文书
中国在我心中演讲稿
2014/09/13 职场文书
自主招生学校推荐信范文
2015/03/26 职场文书
JS Object构造函数之Object.freeze
2021/04/28 Javascript
详解JVM系列之内存模型
2021/06/10 Javascript
Java比较两个对象中全部属性值是否相等的方法
2021/08/07 Java/Android
Python中的 No Module named ***问题及解决
2022/07/23 Python