vue实现点击一个按钮出现弹框,点击弹框外关闭弹框

Posted 淇凌Kirin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue实现点击一个按钮出现弹框,点击弹框外关闭弹框相关的知识,希望对你有一定的参考价值。

vue实现点击一个按钮出现弹框,点击弹框外关闭弹框

效果图展示:

 

View层

<template>
  <div>
    <div class="mask" v-if="showModal" @click="showModal=false"></div>
    <div class="pop" v-if="showModal">
        <button @click="showModal=false" class="btn">点击出现弹框</button>
    </div>
    <button @click="showModal=true" class="btn">点击出现弹框</button>
  </div>
</template>

 

数据层:

<script>
export default {
  data() {
    return {
      showModal: false
    };
  }
};
</script>

 

样式层:

<style scoped>
.mask {
  background-color: #000;
  opacity: 0.3;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1
}
.pop {
  background-color: #fff;
 
  position: fixed;
  top: 100px;
  left: 300px;
  width: calc(100% - 600px);
  height:calc(100% - 200px);
  z-index: 2
}
.btn {
  background-color: #fff;
  border-radius: 4px;
  border: 1px solid blue;
  padding: 4px 12px;
}
</style>

 

关键点:

1.mask层的层级(z-index)要比弹出的pop的层级低。

2.wow,写完啦,就是这么简单....

完整代码:

<template>
  <div>
    <div class="mask" v-if="showModal" @click="showModal=false"></div>
    <div class="pop" v-if="showModal">
        <button @click="showModal=false" class="btn">点击出现弹框</button>
    </div>
    <button @click="showModal=true" class="btn">点击出现弹框</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      showModal: false
    };
  }
};
</script>

<style scoped>
.mask {
  background-color: #000;
  opacity: 0.3;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1
}
.pop {
  background-color: #fff;
 
  position: fixed;
  top: 100px;
  left: 300px;
  width: calc(100% - 600px);
  height:calc(100% - 200px);
  z-index: 2
}
.btn {
  background-color: #fff;
  border-radius: 4px;
  border: 1px solid blue;
  padding: 4px 12px;
}
</style>

 

扩展:按钮在父组件,弹框是一个子组件,会涉及到父子组件之间的传值。

-------

转载于:https://www.cnblogs.com/DZzzz/p/11204805.html

以上是关于vue实现点击一个按钮出现弹框,点击弹框外关闭弹框的主要内容,如果未能解决你的问题,请参考以下文章

自定义弹框,点击提示框外空白区域,让弹框消失

Layui的layer.confirm弹框用法,很详细

vue中点击空白处隐藏弹框(用指令优雅地实现)

vue拦截路由回退弹出弹框

弹框页面点击提交后关闭并刷新首页

vue弹框没点开就调接口