vue3实现点击空白区域隐藏div

 更新时间:2024年04月26日 09:48:22   作者:bangbang给你两锤  
这篇文章主要介绍了vue3实现点击空白区域隐藏div方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

vue3点击空白区域隐藏div

需求是

在主界面中点击按钮,显示组件,点击组件里面的内容时,组件不会隐藏。

但是点击组件外的区域时,组件会进行隐藏

主要内容

一个主界面,我写在了App.vue里面

一个组件,我写在了/src/components/NewModule.vue里面

显隐状态用的时store管理,路径是/src/store/index.ts事先需要安装pinia,不熟悉pinia的可以先看一下pinia简单使用

  • App.vue
<template>
     <!-- 主界面容器,按钮点击显示组件,引入组件 -->
    <el-button type="primary" @click="showBox">点击显示box</el-button>
    <div style="width: 100%;height: 100%; background-color: aquamarine;">
        <NewModel></NewModel>
    </div>
</template>
<script setup lang="ts">
import NewModel from '@/components/NewModel.vue'    //引入组件
import { useUsersStore } from '@/store/index'
const store = useUsersStore()
 
 
const showBox = (e: any) => {
    store.changeState(true)
    e.stopPropagation() //阻止事件冒泡,必须要*,很重要
}
</script>
<style></style>
  • NewModel.vue
<template>
    <!-- 子组件容器 -->
    <div ref="codeDom" style="width: 300px; height: 300px; background-color: antiquewhite;" v-if="store.isHide"></div>
</template>
 
<script lang='ts' setup>
import { watch, ref, onUnmounted } from 'vue'
import { useUsersStore } from '@/store/index'   //引入store
import { storeToRefs } from 'pinia';            //pinia结构化
const store = useUsersStore()
const codeDom = ref()
const { isHide } = storeToRefs(store)
 
//监听点击事件,改变组件的显隐状态
const closeSelect = () => {
    document.addEventListener('click', (e) => {
        if (codeDom.value && !codeDom.value.contains(e.target)) {
            store.changeState(false)
        }
    })
}
 
//监听store状态的改变,若状态为true时,运行closeSelect
watch(isHide, (val) => {
    if (val) {
        closeSelect()
    }
})
 
onUnmounted(() => {
    document.removeEventListener('click', closeSelect)
})
 
</script>
<style lang='scss' scoped></style>
  • store的index.ts
import { defineStore } from 'pinia'
 
export const useUsersStore = defineStore('users', {
    state: () => {
        return {
            isHide: false,
        };
    },
    actions: {
        changeState(val) {
            this.isHide = val
        },
    },
    getters: {},
})

总结

ok,完结,感兴趣的可以做个demo尝试一下 

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue之监听器的使用案例详解

    vue之监听器的使用案例详解

    这篇文章主要介绍了vue之监听器的使用案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • Vue3中watch的最佳用法

    Vue3中watch的最佳用法

    这篇文章主要给大家介绍了关于Vue3中watch用法的相关资料,文章中有详细的代码示例,需要的朋友可以参考下
    2023-04-04
  • Vue工程模板文件 webpack打包配置方法

    Vue工程模板文件 webpack打包配置方法

    这篇文章主要介绍了Vue工程模板文件 webpack打包配置,需要的朋友可以参考下
    2017-12-12
  • Vue2.0实现购物车功能

    Vue2.0实现购物车功能

    这篇文章主要为大家详细介绍了Vue2.0实现购物车功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • vue 路由跳转四种方式实践案例 (带参数)

    vue 路由跳转四种方式实践案例 (带参数)

    本文详细介绍了Vue中通过$router对象实现的四种路由跳转方法:router-link的使用、this.$router.push()和this.$router.replace(),以及参数传递的query与params区别,感兴趣的朋友跟随小编一起看看吧
    2025-05-05
  • Vue动态组件实例解析

    Vue动态组件实例解析

    让多个组件使用同一个挂载点,并动态切换,这就是动态组件。这篇文章主要介绍了Vue动态组件 ,需要的朋友可以参考下
    2017-08-08
  • 关于Uncaught(in promise)TypeError: list is not iterable报错解决

    关于Uncaught(in promise)TypeError: list is not iterable报错

    这篇文章主要给大家介绍了关于Uncaught(in promise)TypeError: list is not iterable报错的解决方法,文中通过示例代码介绍的非常详细,对大家学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • 详解使用Vue.Js结合Jquery Ajax加载数据的两种方式

    详解使用Vue.Js结合Jquery Ajax加载数据的两种方式

    本篇文章主要介绍了详解使用Vue.Js结合Jquery Ajax加载数据的两种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • Vue中使用this.$set()如何新增数据,更新视图

    Vue中使用this.$set()如何新增数据,更新视图

    这篇文章主要介绍了Vue中使用this.$set()实现新增数据,更新视图方式。具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Vue组件之间的参数传递与方法调用的实例详解

    Vue组件之间的参数传递与方法调用的实例详解

    这篇文章主要介绍了Vue组件之间的参数传递与方法调用,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12

最新评论