文字预览蒙层组件

在写这个组件遇见的问题。
布局的时候,装文字的盒子mask这个类。
(1)无法垂直居中??
display: flex;
align-items: center;

(2)关闭按钮无法在盒子mask这个类的正上上方??
改动了一下html布局,让按钮在盒子mask里面。
让后通过子绝父相,进行定位。

组件

<template>
    <div class="page">
        <div v-if="showflag" class="mask">
            <div class="cont-div">
                <van-icon @click="closeHandler" class="close-icon" name="close" />阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
                阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰 阿法发顺丰
            </div>
        </div>
    </div>
</template>

<script>
export default {
    data() {
        return {
        }
    },
    props: {
        showflag: {
            type: Boolean,
            default: false
        }
    },

    methods: {
        closeHandler() {
            this.$emit('close')
        }
    },
}
</script>

<style lang="scss" scoped>
.mask {
    background: rgba(0, 0, 0, 0.4);
    // 水平居中  垂直居中
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    position: absolute;

    //让这个框中水平和垂直方向上居中
    display: flex;
    align-items: center;

    .cont-div {
        width: 311px;
        height: auto;
        background: #ffffff;
        border-radius: 4px;
        margin-left: auto;
        margin-right: auto;
        position: relative;
    }
}
// 控制按钮的方向
.close-icon {
    color: #fff;
    font-size: 20px;
    position: absolute;
    right: -10px;
    top: -48px;
    padding: 10px;
}
</style>

使用组件

<!-- 文字弹出层 -->
<van-button type="primary" @click="openDecMask">文字弹出层</van-button>

<dec-mask :showflag="showflag" @close="hnadlerClose"></dec-mask>

 components: {
     'dec-mask': () => import('../components/dec-Mask')
 },

methods:{
   //打开文字预览组件
   openDecMask() {
      this.showflag = true;
   },
    
   //关闭文字预览组件
   hnadlerClose() {
    this.showflag = false;
  }
}

posted @   何人陪我共长生  阅读(148)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 百万级群聊的设计实践
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
点击右上角即可分享
微信分享提示