javascript - Vue项目中如何使预查询的显示框隐藏
为情所困
为情所困 2017-06-26 10:52:22
[JavaScript讨论组]

Vue项目中,某个组件中的预查询的List列表如何点击除它自己外任意地方使该列表隐藏?


代码如下:
1.数据绑定处:

2.事件绑定:



3.有的同学会说,将输入框设置失去焦点事件,,但是如图的列表显示,,想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,
4.各位路过的同学,瞅一眼啦

为情所困
为情所困

全部回复(4)
女神的闺蜜爱上我

我的项目

mounted () {
      /***
       * 使得其点击之外的部分自动收起
       */
      document.addEventListener('click', (e) => {
        if (!this.$el.contains(e.target)) {
          this.reset()
        }
      })
    }

意思就是点击不在这个组件内的区域收起弹出框,当然你可以把this.$el改成一个ref来判断

世界只因有你
document.addEventListener('click', function(e){
    //通过判断e.target 来判断点击的元素 当不属于下拉框和输入框的时候 隐藏下拉框
})
世界只因有你

考虑了之后我觉得 失焦 还是一个比较理想的事件。
至于你说的
想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,
在绑定的 focusout事件上添加代码如下

eventHandler (event) {
  event.preventDefault()

  // 这里设置input 绑定的data
  
  this.bisible = false
}

这样应该可以解决问题。

女神的闺蜜爱上我

嗯,那个人说的跟我的一样

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号