vue点击当前盒子以外任意地方隐藏当前盒子

方法一: contains方法 用于判断DOM元素的包含关系;

需要注意的是:它以HTMLElement为参数,且返回布尔值。

复制代码
 document.addEventListener('click', (el) => {
        console.log(this.$refs.content.contains(el.target));
      })
复制代码
<template>
    <button @click.stop='showBox'>点击展示隐藏盒子</button>
    <div ref='box' v-show="flag">要隐藏的盒子</div>
</template>
<script>
    export default {
        data(){
           return{
              flag:false
           }
        },
        mounted() {
            document.addEventListener('click', this.hideBox);
        },
        methods:{
            hideBox(e){
                //判断是否点击的是盒子之外
               if (!this.$refs.box.contains(e.target)) {
                   this.flag = false
               }
            },
            showBox(){
                this.flag = !this.flag
            },
        }
    }
</script>

方法二: 可以给盒子加上阻止冒泡 .stop

相关推荐
我是伪码农22 分钟前
外卖餐具智能推荐
linux·服务器·前端
qq_2837200524 分钟前
Python Celery + FastAPI + Vue 全栈异步任务实战
vue.js·python·fastapi
2401_8858850437 分钟前
营销推广短信接口集成:结合营销策略实现的API接口动态变量填充方案
前端·python
小李子呢021139 分钟前
前端八股性能优化(2)---回流(重排)和重绘
前端·javascript
程序员buddha1 小时前
深入理解ES6 Promise
前端·ecmascript·es6
吴声子夜歌1 小时前
ES6——Module详解
前端·ecmascript·es6
剪刀石头布啊2 小时前
原生form发起表单干了啥
前端
剪刀石头布啊2 小时前
表单校验场景,如何实现页面滚动到报错位置
前端
gyx_这个杀手不太冷静2 小时前
大人工智能时代下前端界面全新开发模式的思考(二)
前端·架构·ai编程
GreenTea2 小时前
AI Agent 评测的下半场:从方法论到落地实践
前端·人工智能·后端