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 】
相关推荐:
制作电商网页,电商供应链怎么做?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑
用v-html解决Vue.js渲染中html标签不被解析的问题
jQuery validate插件功能与用法详解
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
如何在万网自助建站中设置域名及备案?
如何用花生壳三步快速搭建专属网站?
动图在线制作网站有哪些,滑动动图图集怎么做?
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
php 三元运算符实例详细介绍
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
如何在IIS中新建站点并解决端口绑定冲突?
,交易猫的商品怎么发布到网站上去?
如何用美橙互联一键搭建多站合一网站?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
如何快速打造个性化非模板自助建站?
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
Laravel Session怎么存储_Laravel Session驱动配置详解
如何在IIS中新建站点并配置端口与IP地址?
北京企业网站设计制作公司,北京铁路集团官方网站?
清除minerd进程的简单方法
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
如何基于PHP生成高效IDC网络公司建站源码?
Laravel怎么判断请求类型_Laravel Request isMethod用法
如何确保FTP站点访问权限与数据传输安全?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
再谈Python中的字符串与字符编码(推荐)
如何在万网自助建站平台快速创建网站?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
如何构建满足综合性能需求的优质建站方案?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
Android利用动画实现背景逐渐变暗
详解MySQL数据库的安装与密码配置
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Thinkphp 中 distinct 的用法解析
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
如何在阿里云域名上完成建站全流程?
Java类加载基本过程详细介绍
jquery插件bootstrapValidator表单验证详解
Laravel API资源类怎么用_Laravel API Resource数据转换
BootStrap整体框架之基础布局组件
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用

