js+css 实现遮罩居中弹出层(随浏览器窗口滚动条滚动)

时间:2022-09-04 08:30:31

本文为大家详细介绍下使用js实现遮罩弹出层居中,且随浏览器窗口滚动条滚动,示例代码如下,感兴趣的朋友可以参考下,

js+css 实现遮罩居中弹出层(随浏览器窗口滚动条滚动)

下面看看我的原始代码:

<!doctype html>

<head>
<meta charset="utf-8" />
<title></title>
<style type="text/css">
* {
margin:0;
padding:0;
}
html {
_background:url(about:blank);
} /** 阻止闪动 in IE6 , 把空文件换成about:blank , 减少请求 */
body {
background:#fff;
font: 12px/1.5 Tahoma, Geneva, \\5b8b\\4f53, sans-serif;
height:100%;
} .img_zfb{
width:100%;
height:100%;
}
.mid {
font-size:12px;
text-align:center;
line-height:24px;
}
/** 遮罩层 **/
#div_masklayer {
background:#000;
display:none;
filter:alpha(opacity = 50);
opacity:0.5;
top:0;
left:0;
height:100%;
width:100%;
z-index:999;
position:fixed;
_position:absolute;
_left: expression(documentElement.scrollLeft + documentElement.clientWidth - this.offsetWidth);
_top: expression(documentElement.scrollTop + documentElement.clientHeight - this.offsetHeight);
}
/** 弹出层 **/
#div_popup {
display:none;
width:240px;
z-index:1000;
left:50%;
top:50%;
position:fixed!important;
/*margin-left:-120px !important;*/
_position:absolute;
_top:expression(eval(document.compatMode && document.compatMode=='CSS1Compat')? documentElement.scrollTop + (document.documentElement.clientHeight - this.offsetHeight)/2: /** IE6 */
document.body.scrollTop + (document.body.clientHeight - this.clientHeight)/2); /* IE5 IE5.5*/
}
.content {
background:#f3f3f3;
border:1px solid #999;
}
.content h3 {
background:#a0a0a0;
color:#fff;
font-size:14px;
height:32px;
line-height:32px;
padding-left:5px;
} </style>
</head>
<body>
<div class="wrap">
<p> 我是正文我是正文我是正文我是正文我是正文我是正文我是正文 <br />
我是正文我是正文我是正文我是正文我是正文我是正文我是正文 <br />
我是正文我是正文我是正文我是正文我是正文我是正文我是正文 <br />
我是正文我是正文我是正文我是正文我是正文我是正文我是正文 <br />
我是正文我是正文我是正文我是正文我是正文我是正文我是正文 </p>
<br /><br /><br /><br /><br /><br /><br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<input type="button" id="btn_test" value="clike me" />
<br /><br /><br /><br /><br />
<div style="width:60px; height:900px; display:block; position:absolute; left:40px; background:red;"> </div>
</div>
<div id="div_masklayer"></div>
<div id="div_popup">
<div class="content">
<h3>我是弹出层 有没有居中?</h3>
<img class="img_zfb" id="img_zfb" src="http://images.cnblogs.com/cnblogs_com/mq0036/508398/o_12.png">
<p class="mid">居中居中居中居中居中居中</p>
<p class="mid">居中居中居中居中居中居中</p>
<p>居中居中居中</p>
</div>
</div>
<script type="text/javascript"> (function ()
{
var btnclick = document.getElementById('btn_test');
var divmasklayer = document.getElementById('div_masklayer');
var divpoppu = document.getElementById('div_popup'); btnclick.onclick = function ()
{
var popup = document.getElementById('div_popup');
var divmasklayer = document.getElementById('div_masklayer');
divmasklayer.style.display = 'block';
popup.style.display = 'block';
//var h = popup.clientHeight;
var h = popup.Height;
with(popup.style)
{
popup.style.marginLeft = -popup.clientWidth / 2 + 'px';
popup.style.marginTop = -popup.clientHeight / 2 + 'px';
}
} divmasklayer.onclick=function(){
document.getElementById('div_popup').style.display="none";
document.getElementById('div_masklayer').style.display="none";
}
})(); </script>
</body>
</html>

参考出处:http://www.jb51.net/article/44354.htm

js+css 实现遮罩居中弹出层(随浏览器窗口滚动条滚动)的更多相关文章

  1. bootstrap 模态框中弹出层 input不能获得焦点且不可编辑

    bootstrap 模态框中弹出层 input不能获得焦点且不可编辑 问题描述:bs框架支持一层model层的情况下,在模态框中弹出了自定义的弹出层.发现自定义弹出层的输入框不能获得焦点且不可编辑. ...

  2. js动态加载js css文件&comma;可以配置文件后辍,防止浏览器缓存

    js的引用,在浏览器,或微信*问经常会遇到文件改了,但就是没有更新的问题,使用此函数可以轻松解决缓存问题只需要把js的引用方式改为使用此函数加载即可 源码如下: /** * js动态加载js css ...

  3. 页面加载异常 清除浏览器静态文件 js css 缓存 js动态加载js css文件&comma;可以配置文件后辍,防止浏览器缓存

    js清除浏览器缓存的几种方法 - 兔老霸夏 - 博客园 https://www.cnblogs.com/Mr-Rocker/p/6031096.html js清除浏览器缓存的几种方法   一.CSS和 ...

  4. 原生JS获取各种高度宽度、浏览器窗口滚动条的位置、元素的几何尺寸名

    1)关于 pageX, clienX,offsetX,layerX pageX:鼠标在页面上的位置,从页面左上角开始,即是以页面为参考点,不随滑动条移动而变化 clientX:鼠标在页面上可视区域的位 ...

  5. layui中弹出层的两种表达方式

    方式一: 定义js中定义html变量 方式二: 设置div :hidden:hidden 布局 数据表格自适应大小: 代码: <style> .btn-container { margin ...

  6. div样式position:fixed&comma;不随屏幕滚动而滚动,导致屏幕太小时弹出层被遮挡,无法滚动查看的解决办法

    window.onscroll = function () { var sl = -Math.max(document.body.scrollTop, document.documentElement ...

  7. JS只弹出一个居中弹出窗口

    var newWindow;//定义一个窗口,有利于窗口间的通讯function makeNewWindow(url) {   if (!newWindow || newWindow.closed) ...

  8. 转 js一个简单实用的弹出层

      关闭 点击查看 >> <html> <head> <title>新文件标题</title> <script type=" ...

  9. js实现遮罩以及弹出可移动登录窗口

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. Android笔记:异步消息处理

    1. Message Message 是在线程之间传递的消息,它可以在内部携带少量的信息,用于在不同线程之间交换数据.上一小节中我们使用到了Message 的what 字段,除此之外还可以使用arg1 ...

  2. CodeForces 688A-Opponents

    题意: Arya在学校有n个敌人(一串含有0,1的数字表示),有一个游戏规则,如果当天这n个敌人全部出席("1"代表出席,),即这串数字全部为"1",则Arya ...

  3. how-to-install-hyper-v-on-a-virtual-machine-in-hyper-v&period;aspx

    BEFORE STARTING IT IS IMPORTANT TO KNOW THAT THIS ENVIRONMENT IS NOT SUPPORTED BY MICROSOFT. USE IT ...

  4. iOS8 无法设置定位服务

    针对iOS8系统,需要在plist文件中添加这两个参数 NSLocationAlwaysUsageDescription = YES NSLocationWhenInUseUsageDescripti ...

  5. SqlServer 常用

    Sql的函数 newId() 获得guid: getDatatime() 获得当前时间: Row_number() 分页常用的函数. 比top 好用的函数select  Row_Number() ov ...

  6. PHP迭代与递归实现无限级分类

    无限级分类是开发中常见的情况,因此本文对常见的无限极分类算法进行总结归纳. 1.循环迭代实现 $arr = [ 1=>['id'=>1,'name'=>'父1','father'=& ...

  7. &period;NET Core 2&period;x中使用Named Options处理多个强类型配置实例

    来源: Using multiple instances of strongly-typed settings with named options in .NET Core 2.x 作者: Andr ...

  8. iis发布----在XP中发布高版本web遇到问题总结

    解决方法是之前在网上看到的,总结一下. 我在vs2010中做的web网页,放到XP系统中发布是遇到问题,XP中的iis版本是iis. 提示.net framework版本上的问题. 1.在网站属性中把 ...

  9. C&plus;&plus;构造函数和析构函数,以及构造函数特殊成员变量和函数的初始化

    body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...

  10. 在MNIST数据集,实现多个功能的tensorflow程序

    使用带指数衰减的学习率的设置.使用正则化来避免过拟合,使用滑动平均模型使得最终模型更加健壮. import tensorflow as tf from tensorflow.examples.tuto ...