最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JS实现弹出浮动窗口(支持鼠标拖动和关闭)实例详解_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:41:37
文档

JS实现弹出浮动窗口(支持鼠标拖动和关闭)实例详解_javascript技巧

JS实现弹出浮动窗口(支持鼠标拖动和关闭)实例详解_javascript技巧:本文实例讲述了JS实现弹出浮动窗口。分享给大家供大家参考。具体如下: 这里介绍的JS弹出浮动窗口,支持鼠标拖动和关闭,点击链接文字后弹出层窗口,也称作是弹出式对话框吧。 关于一些参数说明: bodycontent:要在窗口中显示的内容 title:窗口的标题 r
推荐度:
导读JS实现弹出浮动窗口(支持鼠标拖动和关闭)实例详解_javascript技巧:本文实例讲述了JS实现弹出浮动窗口。分享给大家供大家参考。具体如下: 这里介绍的JS弹出浮动窗口,支持鼠标拖动和关闭,点击链接文字后弹出层窗口,也称作是弹出式对话框吧。 关于一些参数说明: bodycontent:要在窗口中显示的内容 title:窗口的标题 r
 本文实例讲述了JS实现弹出浮动窗口。分享给大家供大家参考。具体如下:

这里介绍的JS弹出浮动窗口,支持鼠标拖动和关闭,点击链接文字后弹出层窗口,也称作是弹出式对话框吧。

关于一些参数说明:

bodycontent:要在窗口中显示的内容
title:窗口的标题
removeable:窗口是否能拖动

注意:内容窗体的高度是height-30px,请计算好要显示的内容高度和宽度。

注:在火狐或chrome下效果最佳,IE8下可能有些小问题。

点击此处查看运行效果:

http://demo.jb51.net/js/2015/js-float-window-mousemove-codes/

运行效果图如下:

具体代码:



Js弹出浮动窗口,支持鼠标拖动和关闭


/**
关于一些参数说明:
*bodycontent:要在窗口显示的内容,dom对象
*title:窗口标题,字符串类型
*removeable:窗口能否拖动,布尔类型
*注意:内容窗体的高度是height-30px,请计算好你要显示的内容的高度和宽度。弹出窗的id为"223238909",所以你的页面不要再取值为"223238909"的id了,以防js执行出错*/
function createdialog(width,height,bodycontent,title,removeable){
 if(document.getElementById("www_jb51_net")==null){
 /*创建窗口的组成元素*/
 var dialog = document.createElement("div");
 var dialogtitlebar= document.createElement("div");
 var dialogbody = document.createElement("div");
 var dialogtitleimg = document.createElement("span");
 var dialogtitle = document.createElement("span");
 var dialogclose = document.createElement("span");
 var closeaction = document.createElement("button");
 /*为窗口设置一个id,id如此怪异是为了尽量避免与其他用户取的id相同而出错*/
 dialog.id = "223238909";
 /*组装对话框标题栏,按从里到外的顺序组装*/
 dialogtitle.innerHTML = title;
 dialogtitlebar.appendChild(dialogtitleimg);
 dialogtitlebar.appendChild(dialogtitle);
 dialogtitlebar.appendChild(dialogclose);
 dialogclose.appendChild(closeaction);
 /*组装对话框主体内容*/
 if(bodycontent!=null){
 bodycontent.style.display = "block";
 dialogbody.appendChild(bodycontent);
 }
 /*组装成完整的对话框*/
 dialog.appendChild(dialogtitlebar);
 dialog.appendChild(dialogbody);
 /*设置窗口组成元素的样式*/
 var templeft,temptop,tempheight//窗口的位置(将窗口放在页面中间的辅助变量)
 var dialogcssText,dialogbodycssText;//拼出dialog和dialogbody的样式字符串
 templeft = (document.body.clientWidth-width)/2;
 temptop = (document.body.clientHeight-height)/2;
 tempheight= height-30;
 dialogcssText= "position:absolute;background:#65c294;padding:1px;border:4px;top:"+temptop+"px;left:"+templeft+"px;height:"+height+"px;width:"+width+"px;";
 dialogbodycssText = "width:100%;background:#ffffff;"+"height:" + tempheight + "px;";
 dialog.style.cssText = dialogcssText;
 dialogtitlebar.style.cssText = "height:30px;width:100%;background:url(images/titlebar.png) repeat;cursor:move;";
 dialogbody.style.cssText = dialogbodycssText;
 dialogtitleimg.style.cssText = "float:left;height:20px;width:20px;background:url(images/40.gif);"+"display:block;margin:4px;line-height:20px;";
 dialogtitle.style.cssText = "font-size:16px;float:left;display:block;margin:4px;line-height:20px;";
 dialogclose.style.cssText = "float:right;display:block;margin:4px;line-height:20px;";
 closeaction.style.cssText = "height:20px;width:24px;border-width:1px;"+"background-image:url(images/close.png);cursor:pointer;";
 /*为窗口元素注册事件*/
 var dialogleft = parseInt(dialog.style.left);
 var dialogtop = parseInt(dialog.style.top);
 var ismousedown = false;//标志鼠标是否按下
 /*关闭按钮的事件*/ 
 closeaction.onclick = function(){
 dialog.parentNode.removeChild(dialog);
 }
 /*实现窗口的移动,这段代码很典型,网上很多类似的代码*/
 if(removeable == true){
 var ismousedown = false;
 var dialogleft,dialogtop;
 var downX,downY;
 dialogleft = parseInt(dialog.style.left);
 dialogtop = parseInt(dialog.style.top);
 dialogtitlebar.onmousedown = function(e){
 ismousedown = true;
 downX = e.clientX;
 downY = e.clientY;
 }
 document.onmousemove = function(e){
 if(ismousedown){
 dialog.style.top = e.clientY - downY + dialogtop + "px";
 dialog.style.left = e.clientX - downX + dialogleft + "px";
 }
 }
 /*松开鼠标时要重新计算当前窗口的位置*/
 document.onmouseup = function(){
 dialogleft = parseInt(dialog.style.left);
 dialogtop = parseInt(dialog.style.top);
 ismousedown = false;
 }
 }
 return dialog; 
 }//end if(if的结束)
}





点击生成窗口


 

希望本文所述对大家的javascript程序设计有所帮助。

文档

JS实现弹出浮动窗口(支持鼠标拖动和关闭)实例详解_javascript技巧

JS实现弹出浮动窗口(支持鼠标拖动和关闭)实例详解_javascript技巧:本文实例讲述了JS实现弹出浮动窗口。分享给大家供大家参考。具体如下: 这里介绍的JS弹出浮动窗口,支持鼠标拖动和关闭,点击链接文字后弹出层窗口,也称作是弹出式对话框吧。 关于一些参数说明: bodycontent:要在窗口中显示的内容 title:窗口的标题 r
推荐度:
标签: 窗口 js 弹出窗口
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top