vue 2.0组件与v-model详解

发布时间 - 2026-01-11 00:23:03    点击率:

前言

大家可能乍一看这个标题,可能会有疑问: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双向数据绑定的方法(最新推荐)  # 绑定  # 就可以  # 的是  # 是一个  # 定值  # 的说  # 也能  # 这是一个  # 要做  # 可以直接  # 有疑问  # 这篇文章  # 谢谢大家  # 要了  # 讲到  # 一件事情  # 要拿  # 扯到  # 写这篇  # 知道了 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  如何用已有域名快速搭建网站?  JS去除重复并统计数量的实现方法  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  java ZXing生成二维码及条码实例分享  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  Swift中循环语句中的转移语句 break 和 continue  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  如何快速登录WAP自助建站平台?  如何在 React 中条件性地遍历数组并渲染元素  如何在阿里云通过域名搭建网站?  免费网站制作appp,免费制作app哪个平台好?  ,网页ppt怎么弄成自己的ppt?  如何快速搭建高效简练网站?  PythonWeb开发入门教程_Flask快速构建Web应用  如何在建站宝盒中设置产品搜索功能?  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  如何用狗爹虚拟主机快速搭建网站?  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  Python正则表达式进阶教程_复杂匹配与分组替换解析  ,交易猫的商品怎么发布到网站上去?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  Angular 表单中正确绑定输入值以确保提交与验证正常工作  移动端脚本框架Hammer.js  个人摄影网站制作流程,摄影爱好者都去什么网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel如何实现事件和监听器?(Event & Listener实战)  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  怎样使用JSON进行数据交换_它有什么限制  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  七夕网站制作视频,七夕大促活动怎么报名?  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  动图在线制作网站有哪些,滑动动图图集怎么做?  简单实现jsp分页  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  如何实现建站之星域名转发设置?  高端建站三要素:定制模板、企业官网与响应式设计优化  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何在Windows虚拟主机上快速搭建网站?  ,南京靠谱的征婚网站?  如何利用DOS批处理实现定时关机操作详解  Laravel怎么上传文件_Laravel图片上传及存储配置