js弹出窗口和遮罩效果

在项目中,经常会用到一种效果就是,点击网页中某个元素时,可以弹出一个图层,这个图层无论是否有滚动条,还是滚动条是否滚动都要保持在当前窗口的正中央,同时在这个窗口的下面有一个遮罩层,使用户不能点击这个元素下面的元素。

具体代码如下:

css如下:

    <style type="text/css">
        #btn1{
            position:fixed;
            right:0;
            bottom:0;
        }
        #div1{
            width:300px;
            height:100px;
            background-color:red;
            position:absolute;
            display:none;
            left:0;
            top:0;
            z-index:2;
        }
        #mask{
            display:none;
            position:absolute;
            background-color:black;
            filter:alpha(opactiy=20);
            opacity:0.2;
            z-index:1;
        }
    </style>
HTML代码如下:

<body style="height:2000px; width:3000px;">
    <input type="button" value="弹出" id="btn1" />
    <div id="div1"><input type="button" value="关闭" id="close" /></div>
    <div id="mask"></div>
</body>

js代码如下:

        $(function () {
            var $win = $(window),
                    $div = $('#div1'),
                    $mask = $('#mask'),
                    $close = $('#close'),
                    flag = false;


            $('#btn1').click(function () {                
                var clientH = $win.height(),
                    clientW = $win.width(),
                    divH = $div.height(),
                    divW = $div.width();
                var t = (clientH - divH) / 2 + $win.scrollTop();
                var l = (clientW - divW) / 2 + $win.scrollLeft();
                $div.css('display', 'block').offset({ 'top': t, 'left': l });

                $mask.show().css({ width: clientW + 'px', height: clientH + 'px' }).offset({ left: $win.scrollLeft(), top: $win.scrollTop() });
                flag = true;

                $close.click(function () {
                    flag = false;
                    $div.hide();
                    $mask.hide();
                });


                $(window).scroll(setMask).resize(setMask);

                function setMask() {
                    if (flag) {
                        $div.css('display', 'block').offset({ 'top': ($win.height() - $div.height()) / 2 + $win.scrollTop(), 'left': ($win.width() - $div.width()) / 2 + $win.scrollLeft() });
                        $mask.show().css({ width: clientW + 'px', height: clientH + 'px' }).offset({ left: $win.scrollLeft(), top: $win.scrollTop() });
                    } else {
                        $div.hide();
                        $mask.hide();
                    }
                }
            });            
        });

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值