全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

vue 2.0组件与v-model详解

前言

大家可能乍一看这个标题,可能会有疑问: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的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的帮助。


# vue  # 组件  # v  # model  # vue2  # vue2.0  # 在Vue2中v-model和.sync区别解析  # vue2和vue3组件v-model区别详析  # Vue2子组件绑定 v-model  # 实现父子组件通信方式  # vue2中如何自定义组件的v-model  # Vue ​v-model相关知识总结  # vue2 v-model/v-text 中使用过滤器的方法示例  # Vue2.0利用 v-model 实现组件props双向绑定的优美解决方案  # vue2 如何实现div contenteditable=“true”(类似于v-model)的效果  # vue2与vue3双向数据绑定的区别说明  # vue 2 实现自定义组件一到多个v-model双向数据绑定的方法(最新推荐)  # 绑定  # 就可以  # 的是  # 是一个  # 定值  # 的说  # 也能  # 这是一个  # 要做  # 可以直接  # 有疑问  # 这篇文章  # 谢谢大家  # 要了  # 讲到  # 一件事情  # 要拿  # 扯到  # 写这篇  # 知道了 


相关文章: 保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  建站之星如何实现PC+手机+微信网站五合一建站?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  建站为何优先选择香港服务器?  css网站制作参考文献有哪些,易聊怎么注册?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  如何正确选择百度移动适配建站域名?  如何快速生成橙子建站落地页链接?  如何通过.red域名打造高辨识度品牌网站?  如何选择高效稳定的ISP建站解决方案?  购物网站制作公司有哪些,哪个购物网站比较好?  seo网站制作优化,网站SEO优化步骤有哪些?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  如何制作算命网站,怎么注册算命网站?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  网站制作费用多少钱,一个网站的运营,需要哪些费用?  常州企业网站制作公司,全国继续教育网怎么登录?  如何登录建站主机?访问步骤全解析  建站主机选哪家性价比最高?  建站之星微信建站一键生成小程序+多端营销系统  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  制作表格网站有哪些,线上表格怎么弄?  网站按钮制作软件,如何实现网页中按钮的自动点击?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  建站之星2.7模板:企业网站建设与h5定制设计专题  建站之星免费版是否永久可用?  存储型VPS适合搭建中小型网站吗?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  建站OpenVZ教程与优化策略:配置指南与性能提升  Android自定义控件实现温度旋转按钮效果  建站中国官网:模板定制+SEO优化+建站流程一站式指南  三星网站视频制作教程下载,三星w23网页如何全屏?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何在服务器上配置二级域名建站?  网站制作价目表怎么做,珍爱网婚介费用多少?  如何在腾讯云服务器快速搭建个人网站?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  如何实现建站之星域名转发设置?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  如何在云主机快速搭建网站站点?  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  网站制作公司排行榜,四大门户网站排名?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  个人摄影网站制作流程,摄影爱好者都去什么网站?  独立制作一个网站多少钱,建立网站需要花多少钱? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。