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 相关文章推荐
JQuery 风格的HTML文本转义
Jul 01 Javascript
浅谈JavaScript数据类型
Mar 03 Javascript
jQuery实现字符串按指定长度加入特定内容的方法
Mar 11 Javascript
jQuery鼠标经过方形图片切换成圆边效果代码分享
Aug 20 Javascript
jquery单击事件和双击事件冲突解决方案
Mar 02 Javascript
AngularJs ng-repeat 嵌套如何获取外层$index
Sep 21 Javascript
详解Vue使用 vue-cli 搭建项目
Apr 20 Javascript
使用JS实现导航切换时高亮显示的示例讲解
Aug 22 Javascript
Vue 刷新当前路由的实现代码
Sep 26 Javascript
Javascript模拟实现new原理解析
Mar 03 Javascript
如何在vue中使用kindeditor富文本编辑器
Dec 19 Vue.js
jquery插件实现代码雨特效
Apr 24 jQuery
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
非常实用的php弹出错误警告函数扩展性强
2014/01/17 PHP
PHP 二维数组根据某个字段排序的具体实现
2014/06/03 PHP
推荐10个提供免费PHP脚本下载的网站
2014/12/31 PHP
JS getStyle获取最终样式函数代码
2010/04/01 Javascript
JQUERY获取form表单值的代码
2010/07/17 Javascript
工作中常用到的JS表单验证代码(包括例子)
2010/11/11 Javascript
JavaScript 判断日期格式是否正确的实现代码
2011/07/04 Javascript
extjs 3.31 TreeGrid实现静态页面加载json到TreeGrid里面
2013/04/02 Javascript
jquery根据锚点offset值实现动画切换
2014/09/11 Javascript
JS获取图片lowsrc属性的方法
2015/04/01 Javascript
jQuery实现平滑滚动页面到指定锚点链接的方法
2015/07/15 Javascript
原生javascript实现图片放大镜效果
2017/01/18 Javascript
vue之数据交互实例代码
2017/06/20 Javascript
详解处理Vue单页面应用SEO的另一种思路
2018/11/09 Javascript
Vue在chrome44偶现点击子元素事件无法冒泡的解决方法
2019/12/15 Javascript
基于JavaScript或jQuery实现网站夜间/高亮模式
2020/05/30 jQuery
[05:14]辉夜杯主赛事第二日 RECAP精彩回顾
2015/12/27 DOTA
python实现bucket排序算法实例分析
2015/05/04 Python
进一步探究Python的装饰器的运用
2015/05/05 Python
Django学习笔记之Class-Based-View
2017/02/15 Python
Python基于Matplotlib库简单绘制折线图的方法示例
2017/08/14 Python
Python爬虫信息输入及页面的切换方法
2018/05/11 Python
Python实现的企业粉丝抽奖功能示例
2019/07/26 Python
Python面向对象封装操作案例详解
2019/12/31 Python
python pip如何手动安装二进制包
2020/09/30 Python
CSS3感应鼠标的背景闪烁和图片缩放动画效果
2014/05/14 HTML / CSS
详解利用css3的var()实现运行时改变scss的变量值
2021/03/02 HTML / CSS
检测浏览器对HTML5和CSS3支持度的方法
2015/06/25 HTML / CSS
AmazeUI框架搭建的方法步骤(图文)
2020/08/17 HTML / CSS
美国医疗用品、医疗设备和家庭保健用品商店:Medical Supply Depot
2018/07/08 全球购物
经济学人订阅:The Economist
2018/07/19 全球购物
澳大利亚最受欢迎的美发和美容在线商店:Catwalk
2018/12/12 全球购物
酒店led欢迎词
2014/01/09 职场文书
英文演讲稿开场白
2014/08/25 职场文书
python3读取文件指定行的三种方法
2021/05/24 Python
天谕手游15杯全调酒配方和调酒券的获得方式
2022/04/06 其他游戏