Js控制弹窗实现在任意分辨率下居中显示


Posted in Javascript onAugust 01, 2013

贴代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>弹出窗口_3water.com</title> 
<link type="text/css" rel="stylesheet" href="window.css"> 
<script language="javascript" type="text/javascript" src="../../jquery/jquery.js"></script> 
<script language="javascript" type="text/javascript" src="window.js"></script> 
<script language="javascript"> 
$(document).ready(function (){ 
$("#btn_center").click(function (){ 
$(window).scroll(function (){ 
popcenterWindow(); 
}); 
}); 
$("#btn_right").click(function (){ 
$(window).scroll(function (){ 
poprightWindow(); 
}); 
}); 
$("#btn_left").click(function (){ 
$(window).scroll(function (){ 
popleftWindow(); 
}); 
}); 
}); 
</script> 
</head> 
<body> 
<input type="button" value="弹出居中的窗口" id="btn_center"> 
<input type="button" value="弹出居右的窗口" id="btn_right"> 
<input type="button" value="弹出居左的窗口" id="btn_left"> 
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> 
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> 
<div class="window" id="center"> 
<div class="title"><img src="close.gif">csdn欢迎您</div> 
<div class="content">哈哈哈哈哈哈哈</div> 
</div> 
<div class="window" id="right"> 
<div class="title"><img src="close.gif">csdn欢迎您</div> 
<div class="content">哈哈哈哈哈哈哈</div> 
</div> 
<div class="window" id="left"> 
<div class="title"><img src="close.gif">csdn欢迎您</div> 
<div class="content">哈哈哈哈哈哈哈</div> 
</div> 
</body> 
</html>

JS
//窗口的高度 
var windowHeight; 
//窗口的宽度 
var windowWidth; 
//弹窗的高度 
var popHeight; 
//弹窗的宽度 
var popWidth; 
//滚动条滚动的高度 
var scrollTop; 
//滚动条滚动的宽度 
var scrollleft; 
//延时的时间 
var timeout; 
function init(){ 
//获得窗口的高度 
windowHeight=$(window).height(); 
//获得窗口的宽度 
windowWidth=$(window).width(); 
//获得弹窗的高度 
popHeight=$(".window").height(); 
//获得弹窗的宽度 
popWidht=$(".window").width(); 
//获得滚动条的高度 
scrollTop=$(window).scrollTop(); 
//获得滚动条的宽度 
scrollleft=$(window).scrollLeft(); 
} 
//定义关闭窗口 
function closeWindow(){ 
$(".title img").click(function (){ 
$(this).parent().parent().hide("slow"); }); 
} 
//定义弹出窗口的方法 
function popcenterWindow(){ 
//先清空上一次的延迟 
clearTimeout(timeout); 
timeout=setTimeout(function (){ 
init(); 
var popY=(windowHeight-popHeight)/2+scrollTop; 
var popX=(windowWidth-popWidht)/2+scrollleft; 
$("#center").animate({top:popY,left:popX},300).show("slow");},300); 
closeWindow(); 
} 
function popleftWindow(){ 
clearTimeout(timeout); 
timeout=setTimeout(function (){ 
init(); 
var popY=windowHeight+scrollTop-popHeight-10; 
var popX=scrollleft-5; 
$("#left").animate({top:popY,left:popX},300).show("slow");},300); 
closeWindow(); 
} 
function poprightWindow(){ 
clearTimeout(timeout); 
timeout=setTimeout(function (){ 
init(); 
var popY=windowHeight-popHeight+scrollTop-10; 
var popX=windowWidth-popWidht+scrollleft-10; 
$("#right").animate({top:popY,left:popX},300).show("slow");},300); 
closeWindow(); 
}

CSS
<SPAN style="FONT-SIZE: 18px">.window{ 
width:250px; 
background-color:#3FF; 
padding:2px; 
margin:5px; 
position:absolute; 
display:none; 
} 
.content{ 
height:150px; 
background-color:#FFF; 
padding:2px; 
font-size:14px; 
overflow:auto; 
} .title{ 
padding:2px; 
color:#999; 
font-size:14px; 
} 
.title img{ 
float:right; 
cursor:pointer; 
}</SPAN>
Javascript 相关文章推荐
让JavaScript拥有类似Lambda表达式编程能力的方法
Sep 12 Javascript
兼容ie、firefox的图片自动缩放的css跟js代码分享
Aug 12 Javascript
浅析JavaScript中的常用算法与函数
Nov 21 Javascript
基于JQuery实现的Select级联
Jan 27 Javascript
简单实现JS对dom操作封装
Dec 02 Javascript
Web Uploader文件上传插件使用详解
May 10 Javascript
Bootstrap导航条的使用和理解3
Dec 14 Javascript
Bootstrap模态框案例解析
Mar 05 Javascript
浅谈Angular路由复用策略
Oct 04 Javascript
关于HTML5的data-*自定义属性的总结
May 05 Javascript
详解Vue组件之间通信的七种方式
Apr 14 Javascript
vue + typescript + 极验登录验证的实现方法
Jun 27 Javascript
Jquery同辈元素选中/未选中效果的实例代码
Aug 01 #Javascript
解决js数据包含加号+通过ajax传到后台时出现连接错误
Aug 01 #Javascript
Javascript 遮罩层和加载效果代码
Aug 01 #Javascript
JS防止用户多次提交的简单代码
Aug 01 #Javascript
纯文字版返回顶端的js代码
Aug 01 #Javascript
JS实现随机化快速排序的实例代码
Aug 01 #Javascript
js中的前绑定和后绑定详解
Aug 01 #Javascript
You might like
php 生成饼图 三维饼图
2009/09/28 PHP
Symfony2框架创建项目与模板设置实例详解
2016/03/17 PHP
PHP判断是否是微信打开还是浏览器打开的方法
2019/02/27 PHP
laravel框架创建授权策略实例分析
2019/11/22 PHP
php使用自带dom扩展进行元素匹配的原理解析
2020/05/29 PHP
js url传值中文乱码之解决之道
2009/11/20 Javascript
Firebug入门指南(Firefox浏览器)
2010/08/21 Javascript
javascript之typeof、instanceof操作符使用探讨
2013/05/19 Javascript
iScroll中事件点击触发两次解决方案
2015/03/11 Javascript
jQuery+html5实现div弹出层并遮罩背景
2015/04/15 Javascript
Ajax与服务器(JSON)通信实例代码
2016/11/05 Javascript
本地Bootstrap文件字体图标引入却无法显示问题的解决方法
2020/04/18 Javascript
Node.js制作简单聊天室
2017/01/12 Javascript
详解JS中的this、apply、call、bind(经典面试题)
2017/09/19 Javascript
对angular2中的ngfor和ngif指令嵌套实例讲解
2018/09/12 Javascript
jQuery+css last-child实现选择最后一个子元素操作示例
2018/12/10 jQuery
Vue 使用formData方式向后台发送数据的实现
2019/04/14 Javascript
JavaScript如何获取一个元素的样式信息
2019/07/29 Javascript
vue实现下拉菜单树
2020/10/22 Javascript
[36:16]完美世界DOTA2联赛PWL S3 access vs Rebirth 第一场 12.19
2020/12/24 DOTA
Python文件操作类操作实例详解
2014/07/11 Python
举例区分Python中的浅复制与深复制
2015/07/02 Python
python 用for循环实现1~n求和的实例
2019/02/01 Python
Python实现E-Mail收集插件实例教程
2019/02/06 Python
Python如何用wx模块创建文本编辑器
2020/06/07 Python
Python调用ffmpeg开源视频处理库,批量处理视频
2020/11/16 Python
钉钉企业内部H5微应用开发详解
2020/05/12 HTML / CSS
Groupon荷兰官方网站:高达70%的折扣
2019/11/01 全球购物
Moss Bros官网:英国排名第一的西装店
2020/02/26 全球购物
职业规划实施方案
2014/06/10 职场文书
抄袭同学作业检讨书1000字
2014/11/20 职场文书
保证书格式
2015/01/16 职场文书
2015暑假实习报告范文
2015/07/13 职场文书
2016应届毕业生就业指导课心得体会
2016/01/15 职场文书
情侣餐厅的创业计划书范本!
2019/07/26 职场文书
如何让vue长列表快速加载
2021/03/29 Vue.js