el-input聚焦失效Autofocus processing was blocked because a document already has a focused element.
问题
目前是想实现双击元素时,切换元素,显示出input框,输入新title,失去焦点再切换回去
<div @dblclick="editTitle()">
<span v-if="draggable">{{ title }}</span>
<el-input
v-else
@blur="loseFocus()"
v-model.trim="titleText"
maxlength="20"
size="small"
/>
</div>
可以看到,切换元素后,输入框并没有聚焦,即使加上autofocus
属性
原因
可能页面有多个el-input或已经聚焦有元素
解决办法
// 编辑title
const editTitle = () => {
_data.draggable = false;
// 页面渲染完成后,输入框自动聚焦
nextTick(() => {
document.querySelector(".el-input__inner").focus();
});
};
// 失去焦点,切换回原元素
const loseFocus = (title, id) => {
_data.draggable = true;
};
分类:
前端 / Vue学习
, 前端
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
2022-01-14 Eclipse中的常用快捷键