html中利用js写一个弹出注册框,原生js实现一个弹出框

本文介绍如何使用JavaScript实现一个简单的弹出注册框,重点在于创建遮罩层、隐藏select下拉框以及构造弹出框的逻辑,同时通过CSS进行样式美化,达到类似新浪微博对话框的效果。
摘要由CSDN通过智能技术生成

其实弹出框的实现非常的简单。网上有很多种类的弹出框,比如jquery ui 的dialog colorbox fancybox等。jquery ui的dialog是一个专业的对话框 而colorbox和fancybox则更适用于播放图片。你可以改造这两个box让他们更像一个对话框。

不过有时候觉得什么都用jquery很累,一个对话框的好坏其实不是取决于功能有多强大,而是兼容性和界面。我喜欢新浪微博那种风格的对话框,所以我用js实现了弹出一个对话框的功能,同时用css美化了弹出框的风格。

先看看效果图:qq截图 图像失真了。

0f463c70b843c9ce73fd500924db1d7d.png

1.弹出遮罩层。/* 弹出遮罩层,去掉注释直接用 */

var back=document.createElement("div");

back.id="back";

var bWidth=parseInt(document.documentElement.scrollWidth);

var bHeight=parseInt(document.documentElement.scrollHeight);

var styleStr="top:0px;left:0px;position:absolute;background-color:rgb(0,0,0);width:"+bWidth+"px;height:"+bHeight+"px;";

styleStr+=(isIe)?"filter:alpha(opacity=30);":"opacity:0.3;";

back.style.cssText=styleStr;

document.body.appendChild(back);

//showBackground(back,15);

用back=document.createElement("div")创建一个div

分别设置这个div的宽度和高度,这里直接将整个浏览器填满。

styleStr是div的css样式字符串。

遮罩层的不透明度这里设为0.3,styleStr+=(isIe)?"filter:alpha(opacity=30);":"opacity:0.3;"; 可以兼容ie和firefox两种浏览器。

最后用document.body.appendChild(back)将back接到body上面。

2.屏蔽select下拉框。

如果你的页面中有下拉框,上面的遮罩层就会始终被这个下拉框挡住一部分,不管你将这个遮罩层的z-index设置得有多高,这是因为在ie8以下,select的优先级比div高,因此要是遮罩层有效,需要将select下拉框先影藏。

调用函数影藏下拉框:if(isIe){

setSelectState('hidden');

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值