javascript - Vue项目中如何使预查询的显示框隐藏
问题描述
Vue项目中,某个组件中的预查询的List列表如何点击除它自己外任意地方使该列表隐藏?
代码如下:1.数据绑定处:
2.事件绑定:
3.有的同学会说,将输入框设置失去焦点事件,,但是如图的列表显示,,想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,4.各位路过的同学,瞅一眼啦
问题解答
回答1:我的项目
mounted () { /*** * 使得其点击之外的部分自动收起 */ document.addEventListener(’click’, (e) => {if (!this.$el.contains(e.target)) { this.reset()} }) }
意思就是点击不在这个组件内的区域收起弹出框,当然你可以把this.$el改成一个ref来判断
回答2:document.addEventListener(’click’, function(e){ //通过判断e.target 来判断点击的元素 当不属于下拉框和输入框的时候 隐藏下拉框})回答3:
考虑了之后我觉得 失焦 还是一个比较理想的事件。至于你说的想要点击选中列表的值,会是的input先失去焦点,,会照成无法选中列表值的情况发生,,,在绑定的 focusout事件上添加代码如下
eventHandler (event) { event.preventDefault() // 这里设置input 绑定的data this.bisible = false}
这样应该可以解决问题。
回答4:嗯,那个人说的跟我的一样
相关文章:
1. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题2. mysql - SQL操作时间的函数?3. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)4. java - mybatis怎么实现在数据库中有就修改,没有就添加5. MYSQL新建用户设置可以远程访问的问题6. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?7. javascript - 用表单提交两个时间段请求后台返回对应数据时出现的一些问题!8. docker-compose中volumes的问题9. angular.js - angularjs的自定义过滤器如何给文字加颜色?10. docker api 开发的端口怎么获取?
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)