如何创建一个JavaScript弹出DIV窗口层的效果


Posted in Javascript onSeptember 25, 2013

在本教程中,我将用最通俗的语言和最简洁的代码给大家演示如何创建一个JavaScript弹出DIV窗口层的效果。

创建一个弹出DIV窗口可能是现在网站/网页制作中最常碰到的问题之一。传统的JavaScript弹窗已经不适合目前网站的设计理念了,理由有二:首先,不友好——生硬的弹出对话框且伴随着“哐”的一声对用户体验是个很大的挑战;其次,兼容性不够强——有相当多的浏览器屏蔽了这种JS的Alert()方法。于是,一个良好用户体验的网站需要一种更合理的解决方案——使用很少的HTML代码,很少的CSS代码和几行的JavaScript代码来模拟浏览器默认的弹出窗口(即替换掉默认的Alert()界面和功能)。

实现原理:

首先,我们将弹出框中的内容放置在一个特殊的DIV层中,然后默认隐藏它(即初始不可见,使用CSS即可实现)。当用户执行某个动作时——比如点击某个链接或者将鼠标光标移动到某个链接上——我们将之前设置好的隐藏层显示在所有页面元素的最上层(将使用JS操作实现)。此外,我们还将在弹出DIV窗口中设置一个按钮来执行——当用户点击此按钮时关闭窗口的功能。

实现过程:

就如我上面提到的,我们首先需要创建一个特殊的DIV层,然后我们将弹出窗口的内容放在这个DIV层里面。在这里,我们将其ID命名为“popupcontent ”以区别于其他DIV层。

<div id="popupcontent">这是一个DIV弹窗效果!</div>

弹出窗口的CSS修饰代码:

接下来,让我们给上面已创建好的这个DIV弹出层进行CSS美化。其中最重要的几个参数分别是:overflow(内容溢出), visibility(可见性) 和position(定位方式)。同时我也给这个窗口效果添加了很多其他代码,但这些只是用于美化,使这个窗口更绚丽。所以,我们最后定义的CSS代码形如:

#popupcontent{ 
position: absolute; 
visibility: hidden; 
overflow: hidden; 
border:1px solid #CCC; 
background-color:#F9F9F9; 
border:1px solid #333; 
padding:5px; 
}

从上面CSS代码中的红色部分可以看出:这个DIV层初始默认状态是不可见的。

大家可以根据需要对以上代码进行美化,但请务必保留position,visibility,overflow三个属性。

JavaScript代码用于触发和显示弹出窗口:

这可能是本教程最重要最有趣的地方了。我们接下来会编写2个过程函数分别用于显示和隐藏上面那个DIV弹窗。当然,这两个函数之中会包含一些主体逻辑。

过程函数中需要顺序包含的逻辑:

计算JavaScript弹出窗口在屏幕上的显示位置(定位);
在弹出窗口中添加一个状态栏(或按钮),用于关闭打开状态下的窗口;
显示弹出窗口。

为了简单起见,本例中我们设置的显示位置是Top:200,Left:200。即以浏览器内容框的左上角为坐标,向下偏移200PX,向左偏移200PX。

弹出窗口的大小我们可以在显示函数的参数中进行设置,包括两个参数:窗口长度和窗口宽度。

如果你需要将本例中的代码进行二次开发,有个地方需要特别注意,那就是获取弹出窗口DIV层的DOM对象,我们可以通过下面这个getElementById函数来获取ID名为“Popcontent”的DOM对象。

var popUp = document.getElementById("popupcontent");

在获取这个(弹出窗口)DOM对象之后,我们可以在JS代码中修改窗口的相对的位置和窗口大小。
popUp.style.top = "200px";//窗口距离浏览器内容区最上方的偏移值 popUp.style.left = "200px";//窗口距离浏览器内容区最左边的偏移值 
popUp.style.width = w + "px";//窗口的宽度 
popUp.style.height = h + "px";//窗口的高度

接下来,我们需要给窗口添加一个“关闭”按钮,用于在窗口开启状态下关闭这个窗口。要完美的实现这一功能,首先我们需要声明一个全局变量,用于存储弹出窗口DIV中的内容。这是因为,如果你在一个页面中显示多个内容不同的弹出窗口,你不需要将按钮重复的复制到这些DIV层中,这样就简化了行为逻辑:
if (baseText == null) baseText = popUp.innerHTML; popUp.innerHTML = baseText + 
"<div id=\"statusbar\"><button onclick=\"hidePopup();\">Close window <button></div>";

最后一个需要注意的地方是这个“关闭”按钮的定位问题。这个很容易实现,设置一下这个按钮对象的向上的空白边即可(空白边的数值设置成稍小于整个弹出窗口的DIV高度即可)。

至此,所有的行为逻辑讲解完毕,最后的弹窗显示函数的完整代码如下:

var baseText = null; function showPopup(w,h){ 
var popUp = document.getElementById("popupcontent"); 
popUp.style.top = "200px"; 
popUp.style.left = "200px"; 
popUp.style.width = w + "px"; 
popUp.style.height = h + "px"; 
if (baseText == null) baseText = popUp.innerHTML; 
popUp.innerHTML = baseText + "<div id=\"statusbar\"><button onclick=\"hidePopup(); 
\">Close window<button></div>"; 
var sbar = document.getElementById("statusbar"); 
sbar.style.marginTop = (parseInt(h)-40) + "px"; 
popUp.style.visibility = "visible"; 
}

隐藏弹出窗口:

隐藏弹出窗口的过程就相当简单了。只需要首先获取弹出窗口那个DIV的DOM对象,然后将其属性设置成“隐藏”即可。

function hidePopup(){ 
var popUp = document.getElementById("popupcontent"); 
popUp.style.visibility = "hidden"; 
}

拓展HTML代码最终实现弹窗效果:

我们需要做的就是在某个链接或者按钮的对应事件上添加JS函数“showPopup() ”即可。

比如,需要在鼠标移动到某连接上时弹出窗口:

<a href="#" onmouseover="showPopup(300,200);" >Open popup</a>

需要在鼠标点击某个连接时弹出窗口:

<a href="#" onclick="showPopup(300,200);" >Open popup</a>

Javascript 相关文章推荐
javascript显示选择目录对话框的代码
Nov 10 Javascript
javascript中的对象创建 实例附注释
Feb 08 Javascript
javascript中兼容主流浏览器的动态生成iframe方法
May 05 Javascript
JS实现3D图片旋转展示效果代码
Sep 22 Javascript
使用JQuery实现的分页插件分享
Nov 05 Javascript
Jquery左右滑动插件之实现超级炫酷动画效果附源码下载
Dec 02 Javascript
angularjs在ng-repeat中使用ng-model遇到的问题
Jan 21 Javascript
jquery仿京东侧边栏导航效果
Mar 02 Javascript
Vue.js简易安装和快速入门(第二课)
Oct 17 Javascript
浅谈Koa2框架利用CORS完成跨域ajax请求
Mar 06 Javascript
AngularJs分页插件使用详解
Jun 30 Javascript
在Vue项目中,防止页面被缩放和放大示例
Oct 28 Javascript
js判断选择时间不能小于当前时间的示例代码
Sep 24 #Javascript
JS 实现导航栏悬停效果(续2)
Sep 24 #Javascript
JS 实现导航栏悬停效果(续)
Sep 24 #Javascript
CSS+jQuery实现的一个放大缩小动画效果
Sep 24 #Javascript
JavaScript中访问节点对象的方法有哪些如何使用
Sep 24 #Javascript
基于jquery实现的省市区级联无ajax
Sep 24 #Javascript
JS.elementGetStyle(element, style)应用示例
Sep 24 #Javascript
You might like
分析PHP中单双引号的误区和双引号小隐患
2016/07/19 PHP
PHP开发中解决并发问题的几种实现方法分析
2017/11/13 PHP
laravel框架语言包拓展实现方法分析
2019/11/22 PHP
利用javascript的面向对象的特性实现限制试用期
2011/08/04 Javascript
js给dropdownlist添加选项的小例子
2013/03/04 Javascript
javascript实现原生ajax的几种方法介绍
2013/09/21 Javascript
JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
2014/08/16 Javascript
Javascript动态创建表格及删除行列的方法
2015/05/15 Javascript
浅谈JS使用[ ]来访问对象属性
2016/09/21 Javascript
概述如何实现一个简单的浏览器端js模块加载器
2016/12/07 Javascript
vuejs响应用户事件(如点击事件)
2017/03/14 Javascript
JavaScript ES6中export、import与export default的用法和区别
2017/03/14 Javascript
webpack配置文件和常用配置项介绍
2017/04/28 Javascript
AngularJS实现的根据数量与单价计算总价功能示例
2017/12/26 Javascript
小程序图片长按识别功能的实现方法
2018/08/30 Javascript
Angular2 自定义表单验证器的实现方法
2018/12/14 Javascript
layui 上传文件_批量导入数据UI的方法
2019/09/23 Javascript
Python深入学习之内存管理
2014/08/31 Python
dataframe设置两个条件取值的实例
2018/04/12 Python
python3实现随机数
2018/06/25 Python
对python列表里的字典元素去重方法详解
2019/01/21 Python
python计算二维矩形IOU实例
2020/01/18 Python
打包PyQt5应用时的注意事项
2020/02/14 Python
jupyter 实现notebook中显示完整的行和列
2020/04/09 Python
通过代码实例了解Python sys模块
2020/09/14 Python
Django haystack实现全文搜索代码示例
2020/11/28 Python
纯HTML5+CSS3制作生日蛋糕代码
2016/11/16 HTML / CSS
适合各种场合的美食礼品:Harry & David
2016/08/03 全球购物
大学生就业推荐信范文
2013/11/29 职场文书
一名毕业生的自我鉴定
2013/12/04 职场文书
青年教师培训方案
2014/02/06 职场文书
秋游活动策划方案
2014/02/16 职场文书
励志演讲稿大全
2014/08/21 职场文书
大班上学期个人总结
2015/02/13 职场文书
北京大学中文系教授推荐的10本小说
2019/08/08 职场文书
SQL Server中常用截取字符串函数介绍
2022/03/16 SQL Server