解决 Vue 中 input 输入框被赋值后,无法再修改和编辑的问题

目录

需求:

出现 BUG:

Bug 代码复现

解决问题:

解决方法1:

解决方法2

关于 $set() 的补充:


需求:

前段时间,接到了一个需求:在选择框中选中某个下拉菜单时,对应的输入框就得自动填上对应的值。比如在药品名称中选取了生理盐水,下栏的药品单位药品用法就会自动填上对应的值

img

img

出现 BUG:

接到这个需求后,我就想到用 v-model 去改变值,但是实现选中菜单自动填写对应的值后,心想用户想修改某个值怎么办?于是我测试时,发现自动填写的值删除不了,重新选取药品名称也无法改变了。那岂不是相当于写死了?

Bug 代码复现

<el-form-item v-for="(drug, index) in dynamicValidateForm.drugs" :key="index"><el-form-item><el-row :gutter="12"><el-col :span='11'><el-select v-model="drug.name" clearable filterable placeholder="药品名称" @change="selectDrug($event,index)"><el-option v-for="item in drugs" :key="item.id" :label="item.药品名称":value="item.药品名称" ></el-option></el-select></el-col><el-col :span='7'><el-input placeholder="药品剂量" v-model="drug.amount" type='number'></el-input></el-col><el-col :span='4'><el-button @click.prevent="removeDrug(drug)" round type="danger"icon="el-icon-delete">删除</el-button></el-col></el-row><el-row :gutter="12"><el-col :span='6'><el-input placeholder="药品单位" v-model="drug.unit"></el-input></el-col><el-col :span='6'><el-input placeholder="用法" v-model="drug.method"></el-input></el-col><el-col :span='6'><el-input placeholder="频率" v-model="drug.freq"></el-input></el-col><el-col :span='6'><el-input placeholder="使用时机" v-model="drug.use"></el-input></el-col></el-row></el-form-item>
</el-form-item>


data () {return {dynamicValidateForm: {domains: [{value: ''}],nursings: [],drugs: [],email: ''},}
},
methods: {selectDrug(e, index) {const _this = this;this.drugs.forEach(ele => {if( ele.药品名称 === e ) {_this.dynamicValidateForm.drugs[index].unit === ele.默认单位)_this.dynamicValidateForm.drugs[index].method === ele.默认用法)}})},
}

解决问题:

然后我查看了官方文档终于明白了:Vue 在实例创建之后添加新的属性到实例上,它不会触发视图更新。

解决方法1:

由此Vue实例创建时,unit 和 method 在dynamicValidateForm中未声明,因此 Vue 就无法对属性执行 getter 和 setter 方法转化过程,以至于dynamicValidateForm 属性不是响应式的,因此无法触发视图更新。所以我们得声明 dynamicValidateForm 这两个对象的属性,如:

data () {return {dynamicValidateForm: {domains: [{value: ''}],nursings: [],drugs: [],email: ''unit: '', // 在 dynamicValidateForm 中声明 unit method: '' // 在 dynamicValidateForm 中声明 method },}
},
methods: {selectDrug(e, index) {const _this = this;this.drugs.forEach(ele => {if( ele.药品名称 === e ) {_this.dynamicValidateForm.drugs[index].unit === ele.默认单位)_this.dynamicValidateForm.drugs[index].method === ele.默认用法)}})},
}

解决方法2

我们可以使用 Vue 的全局 API : $set()赋值:

data () {return {dynamicValidateForm: {domains: [{value: ''}],nursings: [],drugs: [],email: ''},}
},
methods: {selectDrug(e, index) {const _this = this;this.drugs.forEach(ele => {if( ele.药品名称 === e ) {_this.$set( _this.dynamicValidateForm.drugs[index],'unit', ele.默认单位)_this.$set( _this.dynamicValidateForm.drugs[index],'method', ele.默认用法)}})},
}

关于 $set() 的补充:

官方文档:向响应式对象中添加一个 property,并确保这个新 property 同样是响应式的,且触发视图更新。它必须用于向响应式对象上添加新 property,因为 Vue 无法探测普通的新增 property (比如 this.myObject.newProperty = 'hi') 注意对象不能是 Vue 实例,或者 Vue 实例的根数据对象。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/77052.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【含文档+PPT+源码】基于微信小程序的卫生院预约挂号管理系统的设计与实现

项目视频介绍&#xff1a; 毕业作品基于微信小程序的卫生院预约挂号管理系统的设计与实现 课程简介&#xff1a; 本课程演示的是一款基于微信小程序的卫生院预约挂号管理系统的设计与实现&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习…

【Vue】案例——To do list:

【Vue】案例——To do list&#xff1a; 一、案例介绍&#xff1a;二、效果展示&#xff08;如图&#xff09;三、主要功能&#xff1a;四、技术要点&#xff1a;补充&#xff1a;【Vue】Vue模板语法(点击可跳转)补充&#xff1a;【Vue】数据绑定&#xff08;单双向&#xff09…

导入 .sql 文件到 云服务器上的MySQL中

导入 .sql 文件到 云服务器上的MySQL中 步骤 1&#xff1a;确保 .sql 文件已上传到云服务器步骤 2&#xff1a;登录到云服务器步骤 3&#xff1a;检查文件是否成功传输步骤 4&#xff1a;登录 MySQL步骤 5&#xff1a;创建空数据库&#xff08;如果尚未创建&#xff09;步骤 6&…

我的机器学习之路(初稿)

文章目录 一、机器学习定义二、核心三要素三、算法类型详解1. 监督学习&#xff08;带标签数据&#xff09;2. 无监督学习&#xff08;无标签数据&#xff09;3. 强化学习&#xff08;决策优化&#xff09;(我之后主攻的方向) 四、典型应用场景五、学习路线图六、常见误区警示七…

VueDOMPurifyHTML 防止 ​​XSS(跨站脚本攻击)​​ 风险

VueDOMPurifyHTML 是一个 ​​Vue.js 插件​​&#xff0c;用于在 v-html 指令中安全地渲染 HTML 内容&#xff0c;防止 ​​XSS&#xff08;跨站脚本攻击&#xff09;​​ 风险。 ​​作用​​ ​​解决 v-html 的安全问题​​ Vue 的 v-html 会直接渲染原始 HTML&#xff0…

【数据结构】之散列

一、定义与基本术语 &#xff08;一&#xff09;、定义 散列&#xff08;Hash&#xff09;是一种将键&#xff08;key&#xff09;通过散列函数映射到一个固定大小的数组中的技术&#xff0c;因为键值对的映射关系&#xff0c;散列表可以实现快速的插入、删除和查找操作。在这…

How AI could empower any business - Andrew Ng

How AI could empower any business - Andrew Ng References 人工智能如何为任何业务提供支持 empower /ɪmˈpaʊə(r)/ vt. 授权&#xff1b;给 (某人) ...的权力&#xff1b;使控制局势&#xff1b;增加 (某人的) 自主权When I think about the rise of AI, I’m reminded …

微服务的服务调用详解以及常见解决方案对比

微服务服务调用详解 1. 服务调用分类 服务调用根据通信方式、同步性、实现模式可分为以下类型&#xff1a; 按通信协议分类 类型典型协议/框架特点RPC&#xff08;远程过程调用&#xff09;Dubbo、gRPC、Apache Thrift高性能、二进制协议、强类型定义HTTP/RESTSpring RestTe…

MySQL:B+树索引

InnoDB索引方案 为了使用二分法快速定位具体的目录项&#xff0c;假设所有目录项都可以在物理存储器上连续存储&#xff0c;有以下问题&#xff1a; InnoDB使用页为管理存储空间的基本单位&#xff0c;最多只能保证16KB的连续存储空间&#xff0c;记录数据量多可能需要非常大…

THCON 2025

Crypto OTPas_ouf 用10个字符异或加密的jpg图片&#xff0c;通过头得到key再恢复原图 Mammoths Personnal Slot Machine 梅森旋转恢复 from pwn import * from randcrack import RandCrack from tqdm import trange context.log_level errorp remote(74.234.198.209, 33…

3.8 字符串的常用函数

重点&#xff1a;字符串的常用函数 #1.测试转换大小写 lower:大写->小写 upper&#xff1a;小写->大写 swapcase&#xff1a;自动将大写转小写小写转大写 print("ABC".lower()) #abcprint("abc".upper()) #ABCprint…

Docker:SkyWalking 链路追踪的技术指南

1、简述 Apache SkyWalking 是一个开源的 APM(应用性能监控)工具,能够实现分布式系统的全链路监控、性能分析以及服务依赖关系分析。SkyWalking 支持多种语言的探针,提供强大的可视化监控和分析能力,是微服务架构下性能调优和问题排查的利器。 样例代码: https://gitee.…

[Lc] 最长公共子序列 | Fenwick Tree(树状数组):处理动态前缀和

目录 LCR 095. 最长公共子序列 题解 Fenwick Tree&#xff08;树状数组&#xff09;&#xff1a;处理动态前缀和 一、问题背景&#xff1a;当传统方法遇到瓶颈 二、Fenwick Tree核心设计 2.1 二进制索引的魔法 2.2 关键操作解析 更新操作&#xff08;O(log n)&#xff0…

python3.13.0环境安装及python-docx库安装指南

1. Python环境安装 1.1 Windows系统安装Python 下载Python安装包 • 访问Python官网 • 点击"Download Python 3.x.x"&#xff08;推荐使用3.8及以上版本&#xff09; 2. 运行安装程序 • 双击下载的安装包 • 重要&#xff1a;勾选"Add Python to environmen…

前端VUE框架理论与应用(4)

一、计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的。在模板中放入太多的逻辑会让模板过重且难以维护。例如: <div id="example">{{ message.split().reverse().join() }}</div> 在这个地方,模板不再是简单的声明式逻辑。你…

MySQL:存储函数和存储过程

系列文章目录 1.MySQL编程基础 2.程序控制流语句 3.存储过程 4.游标 5.嵌入式SQL 文章目录 系列文章目录前言一、程序控制流语句&#xff1a;二、存储函数&#xff1a; 1.存储函数的特点&#xff1a;2.存储函数的定义&#xff1a;3.调用存储函数 三、存储过程&#xff1a;…

基础贪心算法集合2(10题)

目录 1.单调递增的数字 2.坏了的计算器 3.合并区间 4.无重叠区间 5. 用最少数量的箭引爆气球 6.整数替换 解法1&#xff1a;模拟记忆化搜索 解法2位运算贪心 7.俄罗斯套娃信封问题 补充.堆箱子 8.可被3整除的最大和 9.距离相等的条形码 10.重构字符串 1.单调递增的数字…

RaabitMQ 快速入门

&#x1f389;欢迎大家观看AUGENSTERN_dc的文章(o゜▽゜)o☆✨✨ &#x1f389;感谢各位读者在百忙之中抽出时间来垂阅我的文章&#xff0c;我会尽我所能向的大家分享我的知识和经验&#x1f4d6; &#x1f389;希望我们在一篇篇的文章中能够共同进步&#xff01;&#xff01;&…

语音识别——根据声波能量、VAD 和 频谱分析实时输出文字

SenseVoiceSmall网络结构图 ASR(语音识别)是将音频信息转化为文字的技术。在实时语音识别中,一个关键问题是:如何决定将采集的音频数据输入大模型的最佳时机?固定时间间隔显然不够灵活,太短可能导致频繁调用模型,太长则会延迟文字输出。有没有更智能的方式?答案是肯定…

AI大模型如何重塑科研范式:从“假说驱动”到“数据涌现”

📝个人主页🌹:慌ZHANG-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、引言:科研进入“模型共研”时代 传统科研范式通常以“假设→实验→验证→理论”的方式推进,这一经典路径建立在人类的认知能力与逻辑推理基础上。然而,随着数据规模的爆炸式增长与知识系统的高度复杂…