欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

HTML页面弹出居中可拖拽的自定义窗口层

程序员文章站 2022-03-16 11:44:57
使用div弹出窗口来动态显示内容的原理:首先采用css和html隐藏弹窗中的内容,然后利用javascript(本教程中是jquery)来动态显示它们。这种效果不仅能够充分利用有限...
使用div弹出窗口来动态显示内容的原理:首先采用css和html隐藏弹窗中的内容,然后利用javascript(本教程中是jquery)来动态显示它们。这种效果不仅能够充分利用有限的版面空间,而且能够提高用户体验;更重要的是,它并不影响seo效果(因为它实际存在于页面中,只是初始为不可见状态)

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弹出窗口的效果截图:
HTML页面弹出居中可拖拽的自定义窗口层 
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);//展现登陆框
});


效果图
HTML页面弹出居中可拖拽的自定义窗口层 
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();


现在我们可以点击弹出框的标题栏随意对其在浏览器中拖拽了。