当前位置: 首页 > news >正文

使用 vue3-tel-input电话组件时,为什么通过v-model绑定的默认值无效而 通过:value绑定有效?

问题: 使用第三方 vue3-tel-input电话组件时,通过v-model绑定具有初始值的电话变量,但input框内显示的初始值为空?
排查过程

  • v-model绑定改为 :value绑定后,电话变量初始值竟然能够显示
  • vue3-tel-input组件上绑定有自定义的 input 事件
  • vue3-tel-input组件的子组件,暴露了 value属性和
    e m i t ( ′ i n p u t ′ , v a l u e , t h i s . p h o n e O b j e c t , t h i s . emit('input', value, this.phoneObject, this. emit(input,value,this.phoneObject,this.refs.input) 的触发事件,
    以触发父类通过 @input绑定的方法逻辑。
  • 查看 vue3-tel-input子组件源码,并没有定义 modelValue属性和 @update:modelValue触发事件。
知识点解析:
  • v-model 为vue语法糖,绑定在 <input>组件上编译后的等价展开不同。
    • 绑定在<input>元素,编译后,为 :value@input的组合。@input提供了默认实现。
    • 绑定在组件上,编译后,为 :modelValue@update:modelValue事件。@update:modelValue提供了默认实现。
********************绑定在<input>上*************************
编译前: 
<input v-model="formModel.phoneNumber" />
编译后:
<input:value="formModel.phoneNumber"@input="formModel.phoneNumber = $event.target.value"
/>
********************绑定在组件上*************************
编译前: 
<vue-tel-input v-model="value">
编译后:
<vue-tel-input:modelValue="formModel.phoneNumber"@update:modelValue="newValue => formModel.phoneNumber = newValue"
/>
  • 属性绑定的变量,值只会单向传递,例如通过 :value:modelValue,如果没有额外的触发事件,即子组件中值的变化不会影响到父组件通过 :value:modelValue绑定变量的值。

解决方案

  • 方案一: 使用v-model绑定。优点在于简单,通过默认的input触发事件可以实现双向数据绑定,也可以自定义input事件;
    缺点在于,vue3-tel-input子组件内没有modelValue属性,没有默认实现默认值渲染。适合于没有默认值的场景
  • 方案二: 通过 :value 和自定义 input事件进行变量绑定和数据更新操作逻辑。由于组件内已经暴露 value属性,所以能够实现默认值渲染,也可以自定义input事件逻辑,灵活性高,适合有默认值的场景
http://www.lryc.cn/news/94838.html

相关文章:

  • 【运维工程师学习二】OS系统管理
  • 【前端技巧】CSS常用知识碎片(九)
  • SQL 上升的温度
  • Matlab实现最优化(附上多个完整仿真源码)
  • es下载历史的tar文件
  • 顺畅下载chatglm2-6b的模型文件
  • go语言 socket: too many open files 错误分析
  • 分布式搜索--elasticsearch
  • UE5《Electric Dreams》项目PCG技术解析 之 PCGCustomNodes详解(一)
  • 500万PV的网站需要多少台服务器?
  • 拖动排序功能的实现 - 使用HTML、CSS和JavaScript
  • 【STM32MP135 - ST官方源码移植】第三章:OPTEE源码移植教程
  • 云主机安全-私有密钥安全认证
  • 《Web安全基础》02. 信息收集
  • ffmpeg根据原始视频的帧率进行提取视频帧
  • 从零搭建秒杀服务
  • 数据库应用:CentOS 7离线安装PostgreSQL
  • 【PHP面试题42】Laravel依赖注入实现的原理是怎么样的
  • 如何在本地组策略编辑器中启用或禁用剪贴板历史记录
  • 如何与ChatGPT愉快地聊天
  • 使用Gradio库进行交互式数据可视化:Timeseries模块介绍
  • CONTAINER = ALL是ALTER USER语句的默认值
  • 华为发布大模型时代AI存储新品
  • 5G网络功能介绍
  • 笙默考试管理系统-MyTestMean(13)
  • Tomcat之高可用配置
  • IDEA中springboot的热加载thymeleaf静态html页面
  • Java中可以使用哪些系统架构?怎样选择?
  • 一文详解什么是数据库分片
  • 百度留痕是什么方法排名的