HTML页面弹出居中可拖拽的自定义窗口层
1、在html页面中定义一个p,并在p实现我们需要展示的内容。
. 代码如下:
<body>
<p id="login">
<h2><img src="images/close.png" alt="" class="close" />网站登录</h2>
<form id="loginform" >
<p class="info"></p>
<p class="user">帐 号:<input type="text" name="user" class="text" /></p>
<p class="pass">密 码:<input type="password" name="pass" class="text" /></p>
<p class="button"><input type="button" name="sub" class="submit" value="" /></p>
</form>
<p class="other">注册新用户 | 忘记密码?</p>
</p>
</body>
一图抵千言。让我们看看这个div弹出窗口的效果截图:
2、我所用的css样式
. 代码如下:
#login {
width:350px;
height:250px;
border:1px solid #ccc;
position:absolute;
display:block;
z-index:9999;
background:#fff;
}
#login h2 {
height:40px;
line-height:40px;
text-align:center;
font-size:14px;
letter-spacing:1px;
color:#666;
background:url(images/login_header.png) repeat-x;
margin:0;
padding:0;
border-bottom:1px solid #ccc;
cursor:move;
}
#login h2 img {
float:right;
position:relative;
top:14px;
right:8px;
cursor:pointer;
}
#login p.info {
padding:10px 0 5px 0;
text-align:center;
color:maroon;
}
#login p.user, #login p.pass {
font-size:14px;
color:#666;
padding:5px 0;
text-align:center;
}
#login input.text {
width:200px;
height:25px;
border:1px solid #ccc;
background:#fff;
font-size:14px;
}
#login .button {
text-align:center;
padding:15px 0;
}
#login input.submit {
width:107px;
height:30px;
background:url(images/login_button.png) no-repeat;
border:none;
cursor:pointer;
}
#login .other {
text-align:right;
padding:15px 10px;
color:#666;
}
这里面主要注意的是关于p样式的定义,因为需要居中展示我们使用绝对定位position:absolute;其次因为是弹出层,p必须在最外围,所以通常把z-index设置的非常大,这里我们设置为z-index:9999;还有一点是关于p本身是隐藏的需要设置为display:none,但这里我们需要直接看效果所以直接让它展现使用display:block;
3、我们需要让它居中展示,那么首先就必须获取的高度和宽度,如果有滚动条的水平或者竖向偏移,还需要获取那个长度,通过计算获取p应该浏览器的位置。
. 代码如下:
$(document).ready(function()
{
jquery.fn.extend({
center:function(width,height)
{
return $(this).css("left", ($(window).width()-width)/2+$(window).scrollleft()).
css("top", ($(window).height()-height)/2+$(window).scrolltop()).
css("width",width).
css("height",height);
}
});
});
通过点击按钮让它展现
. 代码如下:
$(".login").click(function ()
{
$("#login").show().center(350,250);//展现登陆框
});
效果图
4、能对弹出框进行拖拽
代码实现
. 代码如下:
$(document).ready(function()
{
jquery.fn.extend({
//拖拽功能
drag:function(){
var $tar = $(this);
return $(this).mousedown(function(e){
if(e.target.tagname =="h2"){
var diffx = e.clientx - $tar.offset().left;
var diffy = e.clienty - $tar.offset().top;
$(document).mousemove(function(e){
var left = e.clientx - diffx;
var top = e.clienty - diffy;
if (left < 0){
left = 0;
}
else if (left <= $(window).scrollleft()){
left = $(window).scrollleft();
}
else if (left > $(window).width() +$(window).scrollleft() - $tar.width()){
left = $(window).width() +$(window).scrollleft() -$tar.width();
}
if (top < 0){
top = 0;
}
else if (top <= $(window).scrolltop()){
top = $(window).scrolltop();
}
else if (top > $(window).height() +$(window).scrolltop() - $tar.height()){
top = $(window).height() +$(window).scrolltop() - $tar.height();
}
$tar.css("left",left + 'px').css("top",top + 'px');
});
}
$(document).mouseup(function(){
$(this).unbind("mousemove");
$(this).unbind("mouseup")
});
});
}
});
});
这里我们只针对p内容中的h2元素可供点击拖拽,如果需要全局p可进行修改,拖拽原理:当鼠标在指定元素上的按下时,获取该鼠标点坐标,通过计算,把图片也移动到相对应的位置,一旦鼠标点击取消,相对应的按下事件也随之取消,页面静止。
调用拖拽方法
. 代码如下:
$("#login").drag();
现在我们可以点击弹出框的标题栏随意对其在浏览器中拖拽了。