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()
        })
      },

这样就完成了,功能实现

GitHub 加速计划 / eleme / element
13
1
下载
A Vue.js 2.0 UI Toolkit for Web
最近提交(Master分支:1 个月前 )
c345bb45 1 年前
a07f3a59 * Update transition.md * Update table.md * Update transition.md * Update table.md * Update transition.md * Update table.md * Update table.md * Update transition.md * Update popover.md 1 年前
Logo

新一代开源开发者平台 GitCode,通过集成代码托管服务、代码仓库以及可信赖的开源组件库,让开发者可以在云端进行代码托管和开发。旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐