本文实例讲述了JS实现漂亮的窗口拖拽效果。分享给大家供大家参考。具体如下:
这是一款漂亮的JS窗口拖拽效果(改变大小/最小化/最大化/还原/关闭)
特点:
① 窗口可以拖动;
② 窗口可以通过八个方向改变大小;
③ 窗口可以最小化、最大化、还原、关闭;
④ 限制窗口最小宽度/高度。
运行效果截图如下:
在线演示地址如下:
http://demo.jb51.net/js/2015/js-win-drug-cha-close-demo/
具体代码如下:
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
<head>
<meta http-equiv=
"Content-Type"
content=
"text/html; charset=utf-8"
/>
<title>窗口拖拽(改变大小/最小化/最大化/还原/关闭)</title>
<style type=
"text/css"
>
body,div,h2{margin:0;padding:0;}
body{background:url(images/bg.jpg);font:12px/1.5 \5fae\8f6f\96c5\9ed1;color:
#333;}
#drag{position:absolute;top:100px;left:100px;width:300px;height:160px;background:#e9e9e9;border:1px solid #444;border-radius:5px;box-shadow:0 1px 3px 2px #666;}
#drag .title{position:relative;height:27px;margin:5px;}
#drag .title h2{font-size:14px;height:27px;line-height:24px;border-bottom:1px solid #A1B4B0;}
#drag .title div{position:absolute;height:19px;top:2px;right:0;}
#drag .title a,a.open{float:left;width:21px;height:19px;display:block;margin-left:5px;background:url(images/tool.png) no-repeat;}
a.open{position:absolute;top:10px;left:50%;margin-left:-10px;background-position:0 0;}
a.open:hover{background-position:0 -29px;}
#drag .title a.min{background-position:-29px 0;}
#drag .title a.min:hover{background-position:-29px -29px;}
#drag .title a.max{background-position:-60px 0;}
#drag .title a.max:hover{background-position:-60px -29px;}
#drag .title a.revert{background-position:-149px 0;display:none;}
#drag .title a.revert:hover{background-position:-149px -29px;}
#drag .title a.close{background-position:-89px 0;}
#drag .title a.close:hover{background-position:-89px -29px;}
#drag .content{overflow:auto;margin:0 5px;}
#drag .resizeBR{position:absolute;width:14px;height:14px;right:0;bottom:0;overflow:hidden;cursor:nw-resize;background:url(images/resize.png) no-repeat;}
#drag .resizeL,#drag .resizeT,#drag .resizeR,#drag .resizeB,#drag .resizeLT,#drag .resizeTR,#drag .resizeLB{position:absolute;background:#000;overflow:hidden;opacity:0;filter:alpha(opacity=0);}
#drag .resizeL,#drag .resizeR{top:0;width:5px;height:100%;cursor:w-resize;}
#drag .resizeR{right:0;}
#drag .resizeT,#drag .resizeB{width:100%;height:5px;cursor:n-resize;}
#drag .resizeT{top:0;}
#drag .resizeB{bottom:0;}
#drag .resizeLT,#drag .resizeTR,#drag .resizeLB{width:8px;height:8px;background:#FF0;}
#drag .resizeLT{top:0;left:0;cursor:nw-resize;}
#drag .resizeTR{top:0;right:0;cursor:ne-resize;}
#drag .resizeLB{left:0;bottom:0;cursor:ne-resize;}
</style>
<script type=
"text/javascript"
>
/*-------------------------- +
获取id, class, tagName
+-------------------------- */
var
get = {
byId:
function
(id) {
return
typeof
id ===
"string"
? document.getElementById(id) : id
},
byClass:
function
(sClass, oParent) {
var
aClass = [];
var
reClass =
new
RegExp(
"(^| )"
+ sClass +
"( |$)"
);
var
aElem =
this
.byTagName(
"*"
, oParent);
for
(
var
i = 0; i < aElem.length; i++) reClass.test(aElem[i].className) && aClass.push(aElem[i]);
return
aClass
},
byTagName:
function
(elem, obj) {
return
(obj || document).getElementsByTagName(elem)
}
};
var
dragMinWidth = 250;
var
dragMinHeight = 124;
/*-------------------------- +
拖拽函数
+-------------------------- */
function
drag(oDrag, handle)
{
var
disX = dixY = 0;
var
oMin = get.byClass(
"min"
, oDrag)[0];
var
oMax = get.byClass(
"max"
, oDrag)[0];
var
oRevert = get.byClass(
"revert"
, oDrag)[0];
var
oClose = get.byClass(
"close"
, oDrag)[0];
handle = handle || oDrag;
handle.style.cursor =
"move"
;
handle.onmousedown =
function
(event)
{
var
event = event || window.event;
disX = event.clientX - oDrag.offsetLeft;
disY = event.clientY - oDrag.offsetTop;
document.onmousemove =
function
(event)
{
var
event = event || window.event;
var
iL = event.clientX - disX;
var
iT = event.clientY - disY;
var
maxL = document.documentElement.clientWidth - oDrag.offsetWidth;
var
maxT = document.documentElement.clientHeight - oDrag.offsetHeight;
iL <= 0 && (iL = 0);
iT <= 0 && (iT = 0);
iL >= maxL && (iL = maxL);
iT >= maxT && (iT = maxT);
oDrag.style.left = iL +
"px"
;
oDrag.style.top = iT +
"px"
;
return
false
};
document.onmouseup =
function
()
{
document.onmousemove =
null
;
document.onmouseup =
null
;
this
.releaseCapture &&
this
.releaseCapture()
};
this
.setCapture &&
this
.setCapture();
return
false
};
//最大化按钮
oMax.onclick =
function
()
{
oDrag.style.top = oDrag.style.left = 0;
oDrag.style.width = document.documentElement.clientWidth - 2 +
"px"
;
oDrag.style.height = document.documentElement.clientHeight - 2 +
"px"
;
this
.style.display =
"none"
;
oRevert.style.display =
"block"
;
};
//还原按钮
oRevert.onclick =
function
()
{
oDrag.style.width = dragMinWidth +
"px"
;
oDrag.style.height = dragMinHeight +
"px"
;
oDrag.style.left = (document.documentElement.clientWidth - oDrag.offsetWidth) / 2 +
"px"
;
oDrag.style.top = (document.documentElement.clientHeight - oDrag.offsetHeight) / 2 +
"px"
;
this
.style.display =
"none"
;
oMax.style.display =
"block"
;
};
//最小化按钮
oMin.onclick = oClose.onclick =
function
()
{
oDrag.style.display =
"none"
;
var
oA = document.createElement(
"a"
);
oA.className =
"open"
;
oA.href =
"javascript:;"
;
oA.title =
"还原"
;
document.body.appendChild(oA);
oA.onclick =
function
()
{
oDrag.style.display =
"block"
;
document.body.removeChild(
this
);
this
.onclick =
null
;
};
};
//阻止冒泡
oMin.onmousedown = oMax.onmousedown = oClose.onmousedown =
function
(event)
{
this
.onfocus =
function
() {
this
.blur()};
(event || window.event).cancelBubble =
true
};
}
/*-------------------------- +
改变大小函数
+-------------------------- */
function
resize(oParent, handle, isLeft, isTop, lockX, lockY)
{
handle.onmousedown =
function
(event)
{
var
event = event || window.event;
var
disX = event.clientX - handle.offsetLeft;
var
disY = event.clientY - handle.offsetTop;
var
iParentTop = oParent.offsetTop;
var
iParentLeft = oParent.offsetLeft;
var
iParentWidth = oParent.offsetWidth;
var
iParentHeight = oParent.offsetHeight;
document.onmousemove =
function
(event)
{
var
event = event || window.event;
var
iL = event.clientX - disX;
var
iT = event.clientY - disY;
var
maxW = document.documentElement.clientWidth - oParent.offsetLeft - 2;
var
maxH = document.documentElement.clientHeight - oParent.offsetTop - 2;
var
iW = isLeft ? iParentWidth - iL : handle.offsetWidth + iL;
var
iH = isTop ? iParentHeight - iT : handle.offsetHeight + iT;
isLeft && (oParent.style.left = iParentLeft + iL +
"px"
);
isTop && (oParent.style.top = iParentTop + iT +
"px"
);
iW < dragMinWidth && (iW = dragMinWidth);
iW > maxW && (iW = maxW);
lockX || (oParent.style.width = iW +
"px"
);
iH < dragMinHeight && (iH = dragMinHeight);
iH > maxH && (iH = maxH);
lockY || (oParent.style.height = iH +
"px"
);
if
((isLeft && iW == dragMinWidth) || (isTop && iH == dragMinHeight)) document.onmousemove =
null
;
return
false
;
};
document.onmouseup =
function
()
{
document.onmousemove =
null
;
document.onmouseup =
null
;
};
return
false
;
}
};
window.onload = window.onresize =
function
()
{
var
oDrag = document.getElementById(
"drag"
);
var
oTitle = get.byClass(
"title"
, oDrag)[0];
var
oL = get.byClass(
"resizeL"
, oDrag)[0];
var
oT = get.byClass(
"resizeT"
, oDrag)[0];
var
oR = get.byClass(
"resizeR"
, oDrag)[0];
var
oB = get.byClass(
"resizeB"
, oDrag)[0];
var
oLT = get.byClass(
"resizeLT"
, oDrag)[0];
var
oTR = get.byClass(
"resizeTR"
, oDrag)[0];
var
oBR = get.byClass(
"resizeBR"
, oDrag)[0];
var
oLB = get.byClass(
"resizeLB"
, oDrag)[0];
drag(oDrag, oTitle);
//四角
resize(oDrag, oLT,
true
,
true
,
false
,
false
);
resize(oDrag, oTR,
false
,
true
,
false
,
false
);
resize(oDrag, oBR,
false
,
false
,
false
,
false
);
resize(oDrag, oLB,
true
,
false
,
false
,
false
);
//四边
resize(oDrag, oL,
true
,
false
,
false
,
true
);
resize(oDrag, oT,
false
,
true
,
true
,
false
);
resize(oDrag, oR,
false
,
false
,
false
,
true
);
resize(oDrag, oB,
false
,
false
,
true
,
false
);
oDrag.style.left = (document.documentElement.clientWidth - oDrag.offsetWidth) / 2 +
"px"
;
oDrag.style.top = (document.documentElement.clientHeight - oDrag.offsetHeight) / 2 +
"px"
;
}
</script>
</head>
<body>
<div id=
"drag"
>
<div class=
"title"
>
<h2>这是一个可以拖动的窗口</h2>
<div>
<a class=
"min"
href=
"javascript:;"
title=
"最小化"
></a>
<a class=
"max"
href=
"javascript:;"
title=
"最大化"
></a>
<a class=
"revert"
href=
"javascript:;"
title=
"还原"
></a>
<a class=
"close"
href=
"javascript:;"
title=
"关闭"
></a>
</div>
</div>
<div class=
"resizeL"
></div>
<div class=
"resizeT"
></div>
<div class=
"resizeR"
></div>
<div class=
"resizeB"
></div>
<div class=
"resizeLT"
></div>
<div class=
"resizeTR"
></div>
<div class=
"resizeBR"
></div>
<div class=
"resizeLB"
></div>
<div class=
"content"
>
① 窗口可以拖动;<br />
② 窗口可以通过八个方向改变大小;<br />
③ 窗口可以最小化、最大化、还原、关闭;<br />
④ 限制窗口最小宽度/高度。
</div>
</div>
</body>
</html>
JS实现漂亮的窗口拖拽效果(可改变大小、最大化、最小化、关闭)的更多相关文章
-
Electron 无边框窗口最大化最小化关闭功能
Electron 无边框窗口最大化最小化关闭功能 目的 实现无边框窗口,并添加最大化最小化和关闭功能 前提 了解Electron 主进程和渲染进程的通讯 了解 BrowserWindow相关功能 操作 ...
-
js实现本地图片文件拖拽效果
如何拖拽图片到指定位置,具体方法如下 在从本地上传图片的时候,如果使用拖拽效果,想想应该是更加的高大上,下面直接上js代码 完整代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 ...
-
canvas实现鼠标拖拽矩形移动改变大小
项目的一个新需求,动态生成矩形框,鼠标点击拖动改变矩形框的位置,并可以调整大小. 之前做过一个小demo,需求类似,但是在canvas内只有一个矩形框,拖动移动,当时记得是用isPointInPath ...
-
Qt 窗口操作函数(置顶、全屏,最大化最小化按钮设置等)
一.窗口置顶 与 取消置顶 void MainWindow::on_windowTopButton_clicked() { if (m_flags == NULL) { m_flags = windo ...
-
React.js实现原生js拖拽效果及思考
一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...
-
js拖拽效果
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
-
nw.js FrameLess Window下的窗口拖拽与窗口大小控制
nw.js FrameLess Window下的窗口拖拽与窗口大小控制 很多时候,我们觉得系统的Frame框很难看,于是想自定义. 自定义Frame的第一步是在package.config文件中将fr ...
-
js div浮动层拖拽效果代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
-
原生js简单实现拖拽效果
实现弹窗拖拽效果的原理是:按下鼠标并移动——拖拽移动物体,抬起鼠标——停止移动.主要触发三个事件:onmousedown.onmousemove以及onmouseup: 首先搭建结构:一个宽350px ...
随机推荐
-
rabbitMQ+yii2 使用
安装rabbitMQ 见此文章 http://www.cnblogs.com/zxxyx/p/6229613.html 安装好之后 出现此目录: 然后需要yii里面进行载入: 这个目录下面: 加上这个 ...
-
[Android基础论]为何Activity退出之后,系统没有调用onDestroy方法?
首先,问题是如何出现的? 晚上复查代码,发现一个activity没有调用自己的ondestroy方法 我表示非常的费解,于是我检查了下代码. 发现再finish代码之后接了如下代码 finish(); ...
-
bug修复复盘
mybatis与数据库交互时,报了莫名其妙的错,日志中显示的Stack Trace中报错的代码行数与IDE中还一致,逐重启tomcat,异常消失. 故障复盘:没有重启tomcat,使用copy命令直接 ...
-
iOS 9 地图定位崩溃 n: &#39;Invalid parameter not satisfying: !stayUp || CLClientIsBackgroundable(internal->;fClient)&#39;
报错详情: *** Assertion failure in -[CLLocationManager setAllowsBackgroundLocationUpdates:], /BuildRoot/ ...
-
C# .NET中的 反射的应用
C#中的映射 C#编译后的文件主要由IL代码和元数据组成,元数据为.NET组件提供了丰富的自描述特性,它使得我们可以在代码运行时获知组件中的类型等重要的信息.C#中这是通过一种称作映射(Reflect ...
-
Github开源项目(企业信息化基础平台)
JEEPlatform 一款企业信息化开发基础平台,可以用于快速构建企业后台管理系统,集成了OA(办公自动化).SCM(供应链系统).ERP(企业资源管理系统).CMS(内容管理系统).CRM(客户关 ...
-
Jquery ajaxfileupload.js结合.ashx文件实现无刷新上传
先上几张图更直观展示一下要实现的功能,本功能主要通过Jquery ajaxfileupload.js插件结合ajaxUpFile.ashx一般应用程序处理文件实现Ajax无刷新上传功能,结合NPOI2 ...
-
【ARM】ARM体系结构-GPIO
GPIO Gerneral-Purpose IO ports,即通用IO口. 在嵌入式系统中常常有数量众多,但是却比较简单的外部设备/电路. 对这些设备/电路,有的需要CPU为之提供控制手段,有 ...
-
Css格式化/压缩(代码)
function $() { var elements = new Array(); for (var i = 0; i < arguments.length; i++) { var eleme ...
-
MyBatis批量更新for Mysql 实例
<update id="UpdatePwd" parameterType="java.util.List"> UPDATE FP_USER_BASE ...