Vue项目中,某个组件中的预查询的List列表如何点击除它自己外任意地方使该列表隐藏?
代码如下:
1.数据绑定处:
2.事件绑定:
3.有的同学会说,将输入框设置失去焦点事件,,但是如图的列表显示,,想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,
4.各位路过的同学,瞅一眼啦
Vue项目中,某个组件中的预查询的List列表如何点击除它自己外任意地方使该列表隐藏?
代码如下:
1.数据绑定处:
2.事件绑定:
3.有的同学会说,将输入框设置失去焦点事件,,但是如图的列表显示,,想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,
4.各位路过的同学,瞅一眼啦
document.addEventListener('click', function(e){
//通过判断e.target 来判断点击的元素 当不属于下拉框和输入框的时候 隐藏下拉框
})
考虑了之后我觉得 失焦 还是一个比较理想的事件。
至于你说的想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,
在绑定的 focusout
事件上添加代码如下
eventHandler (event) {
event.preventDefault()
// 这里设置input 绑定的data
this.bisible = false
}
这样应该可以解决问题。
13 回答13.1k 阅读
7 回答2.3k 阅读
3 回答1.4k 阅读✓ 已解决
6 回答1.5k 阅读✓ 已解决
2 回答1.5k 阅读✓ 已解决
3 回答1.5k 阅读✓ 已解决
2 回答1.2k 阅读✓ 已解决
我的项目
意思就是点击不在这个组件内的区域收起弹出框,当然你可以把this.$el改成一个ref来判断