popover中有input
但是在点击触发popover时,input未获取到焦点
需要手动点击才能输入,效果如图

影响用户体验, 需要改进一下
首先想到的方法是 给el-input 添加ref,获取后调用focus()
<el-input
placeholder="请输入内容"
v-model="value"
clearable
@keyup.enter.native="confirm"
ref="sInput"
>
this.$refs.sInput.focus()
但是不生效。
查阅资料后发现 需要在popover的show event中手动给el-input获取焦点
<el-popover placement="bottom" width="200" trigger="manual" v-model="visible" @show="showPopover">
<el-input
placeholder="请输入内容"
v-model="value"
clearable
@keyup.enter.native="confirm"
ref="sInput"
>
</el-popover>
methods: {
showPopover () {
this.$nextTick(() => {
this.$refs.sInput.focus()
})
},
这样就完成了,功能实现
博客内容讲述了在使用element-ui的popover组件时遇到的问题,即popover内的input元素在触发显示时无法自动获取焦点,导致用户必须手动点击才能开始输入。为了解决这个问题,作者通过在popover的show事件中利用$nextTick延迟执行,成功地使input在popover显示后自动获取焦点。这种方法提高了用户体验,避免了额外的手动操作。
1522

被折叠的 条评论
为什么被折叠?



