input+disabled/readonly问题

背景:

vue2+elementui

<el-input v-model="inputForm.projectName" class="input-font" :disabled="projectDisabled" placeholder="请选择"   :readonly="isReadonly"><el-button  slot="append"  @click="showChooseProject" icon="el-icon-search"></el-button>
</el-input>

<input>元素设置了disabledreadonly属性,再点击按钮修改inputForm.projectName字段后,校验出错,以及input显示值不更新的问题。

解决方法

校验出错-自定义验证逻辑

原因分析:

表单字段被 readonlydisabled,可能影响验证触发;

验证触发的时机和值更新的时机有先后,导致校验出错;

解决办法:

自定义验证逻辑,代码如下:

<el-form-item label="项目" prop="projectName" :rules="[{ required: true, validator: validateProjectName, trigger: ['blur','change']  }, ]"><el-input v-model="inputForm.projectName" class="input-font" :disabled="projectDisabled" placeholder="请选择"   readonly><el-button  slot="append" :disabled="disabled" @click="showChooseProject" icon="el-icon-search"></el-button></el-input>
</el-form-item>
// 自定义验证逻辑validateProjectName  (rule, value, callback)  {// 判断值是否为空if (!this.inputForm.projectName) {callback(new Error('项目不能为空'));}  else {callback();  // 验证通过}},

validateProjectName 函数中获取value的时机和修改时机有先后,所以验证结果不准确,所以直接把验证inputForm.projectName即可

input显示值不更新 - 手动触发更新

this.inputForm.projectName = name;
this.$forceUpdate();

由于设置了disable | readonly属性,回显失败。猜测是diff算法没检测到修改,没有渲染等导致。所以直接强制更新,搞定。

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

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

相关文章

Office2019下载安装教程(2025最新永久方法)(附安装包)

文章目录 Office2019安装包下载Office2019一键安装步骤&#xff08;超详细&#xff01;&#xff09; 大家好&#xff01;今天给大家带来一篇超实用的Office2019专业版安装教程&#xff01;作为日常办公和学习的必备软件&#xff0c;Office的安装对很多朋友来说可能有点复杂&…

【编译工具】(版本控制)Git + GitHub Actions:自动化工作流如何让我的开发效率提升200%?

目录 引言&#xff1a;现代开发中版本控制和 CI/CD 的重要性 一、Git&#xff1a;为什么它是版本控制的首选&#xff1f; &#xff08;1&#xff09;Git 的核心优势 &#xff08;2&#xff09;Git 高效工作流示例 ① 功能开发流程 ② 紧急修复流程 二、GitHub Acti…

码蹄杯真题分享

我的个人主页 我的专栏&#xff1a; 人工智能领域、java-数据结构、Javase、C语言&#xff0c;MySQL&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01; 点赞&#x1f44d;收藏❤ 1&#xff1a;房间打扫&#xff08;题目链接&#xff09; 思路&#xff1a;要想…

小米玄戒O1架构深度解析(二):多核任务调度策略详解

上篇文章中&#xff0c;就提到了小米玄戒O1的多核任务调度策略&#xff0c;但讲得不够详细&#xff0c;尤其是对于完全公平调度器和能效感知调度&#xff0c;这次我们就深度剖析一下这两种调度策略。 目录 1. 完全公平调度器&#xff08;CFS&#xff09;1.1 完全公平调度基本原…

【技巧】win10和ubuntu互相挂在共享文件夹

回到目录 【技巧】win10和ubuntu互相挂在共享文件夹 1. ubuntu挂载win10共享文件夹 $ sudo apt update $ sudo apt install cifs-utils $ sudo mkdir /mnt/[这里改为ubuntu共享目录名] $ sudo mount -t cifs -o usernameadministrator //[这里改为win10机器IP]/[这里改为win…

线程(下)【Linux操作系统】

文章目录 线程控制线程共享进程地址空间中的所有数据线程会瓜分进程的时间片线程相关库函数库函数&#xff1a;pthread_create库函数&#xff1a;pthread_self库函数&#xff1a;pthread_join库函数&#xff1a;pthread_exit库函数&#xff1a;pthread_cancel[尽量少用]库函数&…

Linux 任务调度策略

&#x1f31f; 概述 Linux 内核以线程&#xff08;任务&#xff09;为单位进行调度&#xff0c;支持 SCHED_FIFO 和 SCHED_RR&#xff08;实时调度&#xff09;以及 SCHED_OTHER&#xff08;基于 CFS&#xff0c;非实时调度&#xff09;。 &#x1f50d; 调度策略 1. SCHED_…

芯片金属层M1、M2区别

在芯片设计中&#xff0c;M1&#xff08;第一层金属&#xff09;和 M2&#xff08;第二层金属&#xff09;是常见的金属层&#xff0c;它们在用途、布线方向、设计规则和应用场景等方面存在一些主要区别。以下是详细对比&#xff1a; 1. 用途 M1&#xff08;第一层金属&#x…

Linux离线环境下安装Lean 4开发环境的完整指南

文章目录 一、准备工作1. 在线环境下载必要文件2. 传输文件至离线环境 二、安装elan工具链管理器1. 解压并安装elan2. 配置环境变量3. 验证elan安装 三、安装Lean 4二进制包1. 解压Lean 4二进制文件2. 注册工具链到elan 四、安装VS Code Lean 4插件1. 使用VS Code界面安装插件 …

ffmpeg windows 32位编译

ffmpeg windows 32位编译 编译后程序下载 编译方式 自动编译工具套件 – https://github.com/m-ab-s/media-autobuild_suite github克隆完成后&#xff0c;双击bat文件打开编译窗口&#xff0c;注意git检出的目录需要简短&#xff0c;最好选一个盘的根目录。 选择编译版本…

P1216 [IOI 1994] 数字三角形 Number Triangles

题目描述 观察下面的数字金字塔。 写一个程序来查找从最高点到底部任意处结束的路径&#xff0c;使路径经过数字的和最大。每一步可以走到左下方的点也可以到达右下方的点。 在上面的样例中&#xff0c;从 7 → 3 → 8 → 7 → 5 7 \to 3 \to 8 \to 7 \to 5 7→3→8→7→5 的…

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…

Css实现悬浮对角线边框动效

动画效果展示 鼠标悬停时&#xff0c;一个带有圆角的水绿色边框会从右上和左下两个方向快速展开&#xff0c;随后颜色缓慢填充&#xff1b;移出鼠标时颜色先褪去&#xff0c;边框再快速收缩消失&#xff0c;形成具有节奏感的呼吸式动画。 &#x1f4dc; 动画原理说明 一、核…

技术创新究竟包含什么?

技术创新指的是引入新技术或改进现有技术&#xff0c;以创造新颖且更优的产品、服务或流程的过程。它涉及应用科学和技术知识开发创新解决方案&#xff0c;以创造价值、提高效率、推动增长&#xff0c;并满足用户和客户不断变化的需求。 技术创新可以有多种形式&#xff0c;例…

ArcGIS+AI:涵盖AI大模型应用、ArcGIS功能详解、Prompt技巧、AI助力的数据处理、空间分析、遥感分析、二次开发及综合应用等

&#x1f310; GIS凭借其强大的空间数据处理能力、先进的空间分析工具、灵活的地图制作与可视化功能&#xff0c;以及广泛的扩展性和定制性&#xff0c;已成为地理信息科学的核心工具。它在城市规划、环境科学、交通管理等多个学科领域发挥着至关重要的作用。与此同时&#xff…

数据淘金时代:公开爬取如何避开法律雷区?

首席数据官高鹏律师团队编著 一、“数字淘金热”里的暗礁&#xff1a;那些被爬垮的平台和赔哭的公司 前阵子某电商平台的“商品比价爬虫”上了热搜&#xff0c;技术小哥本想靠抓竞品数据优化定价&#xff0c;结果收到法院传票——对方服务器被爬瘫痪&#xff0c;索赔300万。这…

在ARM 架构的 Mac 上 更新Navicat到17后连接Oracle时报错:未加载 Oracle 库。

一&#xff1a;问题 使用的M1芯片的Mac&#xff0c;将Navicat更新到了17版本后&#xff0c;原本正常的Oracle数据库无法连接&#xff0c;报错&#xff1a;未加载 Oracle 库。而sqlserver库可以正常连接 二&#xff1a;解决方法 打开聚焦搜索——〉打开访达——〉在应用程序中…

Springboot仿抖音app开发之用短视频务模块后端复盘及相关业务知识总结

Springboot仿抖音app开发之用户业务模块后端复盘及相关业务知识总结 BO类和VO类的区别 BO (Business Object) - 业务对象 定义: 业务对象是包含业务逻辑的领域模型用途: 主要用于封装业务逻辑相关的数据&#xff0c;在业务层(Service层)之间传递特点: 与业务处理密切相关通常…

SQL-事务(2025.6.6-2025.6.7学习篇)

1、简介 事务是一组操作的集合&#xff0c;它是一个不可分割的工作单位&#xff0c;事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求&#xff0c;即这些操作要么同时成功&#xff0c;要么同时失败。 默认MySQL的事务是自动提交的&#xff0c;也就是说&#xff0…

《Ansys SIPI仿真技术笔记》 E-desk IBIS模型导入

技术笔记日期&#xff1a;20250611 00 背景和疑问 当在Circuit中准备载入IBIS时&#xff0c;工作界面会弹出如下界面&#xff1a; 那么具体Pin Import和Buffer Import有和区别&#xff1f; 何时该按哪个导入呢&#xff1f; 01 思考和记录 1. Buffer Import VS Pin Import…