網頁模組拖動,Js仿Google和Windows Live的層拖拽
<HTML>
<HEAD>
<TITLE>仿Google和Windows Live的拖拽</TITLE>
<style type="text/css">
body
{
margin:10px;
}
#dragHelper
{
position:absolute;/*重要*/
border:2px dashed #000000;
background-color:#FFFFFF;
filter: alpha(opacity=30);
}
.normal
{
position:absolute;/*重要*/
width:300px;
#height:10px;
border:1px solid #666666;
background-color:#FFFFFF;
}
.over
{
position:absolute;/*重要*/
width:300px;
#height:10px;
border:1px solid #666666;
background-color:#f3f3f3;
filter: alpha(opacity=50);
}
.dragArea {
CURSOR: move;
}
</style>
</HEAD>
<BODY oncontextmenu="window.event.returnValue=false">
<input type="text" id="evt" name="eventValue" size="40" />
<div id="dragHelper" style="display:none"></div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td><a href="#">baidu.com</a></td><td dragArea="yes" class="dragArea">........</td><td><a href="#"
onclick="openClose(this)">-</a> x</td></tr>
<tr><td colspan="3">地址:http://www.baidu.com</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td>新浪</td><td dragArea="yes" class="dragArea">........</td><td><a href="#" onclick="openClose(this)">-</a>
x</td></tr>
<tr><td colspan="3">地址:http://www.sina.com.cn</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td>好搜</td><td dragArea="yes" class="dragArea">........</td><td><a href="#" onclick="openClose(this)">-</a>
x</td></tr>
<tr><td colspan="3">地址:http://www.haosou.com</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td>QQ</td><td dragArea="yes" class="dragArea">........</td><td><a href="#" onclick="openClose(this)">-</a>
x</td></tr>
<tr><td colspan="3">地址:http://www.qq.com</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div><A href="http://www.999jiujiu.com/">http://www.999jiujiu.com/</A></div>
</BODY>
<SCRIPT LANGUAGE="JavaScript">
<!--
var dragObjs = [];//可以拖拽的元素陣列
var dragObjTops = [];
var dragHelper = document.getElementById("dragHelper");//拖拽時位置框
var dragObj = null;//拖拽物件元素
var dragObjPos = 0;
var dragObjOffset = {left:0,top:0};//拖拽物件原始位置
var mouseInDragObjOffset = {x:0,y:0};//滑鼠在拖拽物件中的相對位置
var initHeight = 40;
Number.prototype.NaN0=function(){return isNaN(this)?0:this;}
function getPosition(e){//獲取元素相對文件的絕對位置
var left = 0;
var top = 0;
while (e.offsetParent){
left += e.offsetLeft;
top += e.offsetTop;
e = e.offsetParent;
}
left += e.offsetLeft;
top += e.offsetTop;
return {x:left, y:top};
}
function mouseCoords(ev){//獲取滑鼠相對文件的絕對位置
if(ev.pageX || ev.pageY){
return {x:ev.pageX, y:ev.pageY};
}
return {
x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,
y:ev.clientY + document.body.scrollTop - document.body.clientTop
};
}
function getMouseOffset(target, ev){//獲取滑鼠相對元素的相對位置
ev = ev || window.event;
var elementPos = getPosition(target);
var mousePos = mouseCoords(ev);
return {x:mousePos.x - elementPos.x, y:mousePos.y - elementPos.y};
}
function mouseDown(ev){
ev = ev || window.event;
target = ev.srcElement || ev.target;
if(dragObj){
return;
}
var dragArea = false;
if(target.getAttribute("dragArea")){
dragArea = true;
}
while(!target.getAttribute("isDragObj")){
if(target.tagName=="HTML")
break;
target = target.parentNode;
}
if(dragArea && target.getAttribute("isDragObj")){
dragObj = target;
//重寫的目的是讓當前物件在最上層
document.body.removeChild(dragObj);
document.body.appendChild(dragObj);
//記錄下拖拽物件原始位置
dragObjOffset.left = dragObj.style.left;
dragObjOffset.top = dragObj.style.top;
dragObj.className = dragObj.getAttribute("overClass");
//滑鼠在拖拽物件中的相對位置
mouseInDragObjOffset = getMouseOffset(dragObj, ev);
dragHelper.style.left = dragObj.style.left;
dragHelper.style.top = dragObj.style.top;
dragHelper.style.width = dragObj.offsetWidth;
dragHelper.style.height = dragObj.offsetHeight;
dragHelper.style.display = "";
//alert(dragObj.offsetWidth+":"+dragObj.clientWidth);
}
}
function mouseUp(ev){
ev = ev || window.event;
target = ev.srcElement || ev.target;
if(dragObj){
dragObj.style.left = dragHelper.style.left;
dragObj.style.top = dragHelper.style.top;
dragHelper.style.display = "none";
dragObj.className = dragObj.getAttribute("dragClass");
dragObj = null;
}
}
function mouseMove(ev){
ev = ev || window.event;
if(dragObj) {
var mousePos = mouseCoords(ev);
/*dragHelper.style.left = dragObjOffset.left;
dragHelper.style.top = dragObjOffset.top;
dragHelper.style.width = dragObj.offsetWidth;
dragHelper.style.height = dragObj.offsetHeight;
dragHelper.style.display = "";*/
var windowWidth = document.body.offsetWidth;//視窗寬度
var windowHeight = document.body.offsetHeight;//視窗高度
//拖拽物件應該所在當前位置
var dragObjLeft = mousePos.x - mouseInDragObjOffset.x;
var dragObjTop = mousePos.y - mouseInDragObjOffset.y;
//增加判斷,不然拖拽物件拖出瀏覽器視窗
if(dragObjLeft >= 0 && dragObjLeft <= windowWidth - dragObj.offsetWidth - 20)
dragObj.style.left = dragObjLeft;
if(dragObjTop >=0)
dragObj.style.top = dragObjTop;
repaint();
}
}
//克隆物件
function cloneObject(srcObj, destObj){
destObj = srcObj.cloneNode(true);
}
function makeDraggable(element){
element.setAttribute("isDragObj", "y");
}
function repaint(){
for(i=0; i<dragObjs.length; i++){
if(dragObjs[i] == dragObj){
dragObjPos = i;
dragObjs[i] = dragHelper;
break;
}
}
if(dragObjPos>0 && parseInt(dragObj.style.top)<parseInt(dragObjs[dragObjPos-1].style.top)){
dragObjs[dragObjPos] = dragObjs[dragObjPos-1];
dragObjs[dragObjPos-1] = dragHelper;
dragObjPos = dragObjPos - 1;
}
if(dragObjPos<dragObjs.length-1 && parseInt(dragObj.style.top)>parseInt(dragObjs[dragObjPos+1].style.top)){
dragObjs[dragObjPos] = dragObjs[dragObjPos+1];
dragObjs[dragObjPos+1] = dragHelper;
dragObjPos = dragObjPos + 1;
}
paintDragObjs();
dragObjs[dragObjPos] = dragObj;
}
function paintDragObjs(){
var h = 40;
for(i=0; i<dragObjs.length; i++){
dragObjs[i].style.left = 20;
dragObjs[i].style.top = h;
h += dragObjs[i].offsetHeight + 10;
}
}
function openClose(obj){
obj.innerHTML = obj.innerHTML=="-"?"+":"-";
while(obj.tagName != "TBODY"){
obj = obj.parentNode;
}
for(i=0; i<obj.childNodes.length; i++){
if(obj.childNodes[i].nodeName == "#text"
|| obj.childNodes[i].getAttribute("bar")){ continue; }
obj.childNodes[i].style.display=obj.childNodes[i].style.display==""?"none":"";
}
paintDragObjs();
}
document.onmousedown = mouseDown;
document.onmouseup = mouseUp;
document.onmousemove = mouseMove;
window.onload = function(){
var objs = document.getElementsByTagName("Div");
for(i=0; i<objs.length; i++){
var item = objs.item(i);
//if(i==1)item.style.height=150;
if(item.getAttribute("overClass")){
makeDraggable(item);
dragObjs.push(item);
item.style.left = 20;
item.style.top = initHeight;
dragObjTops.push(initHeight);
initHeight += item.offsetHeight + 10;
}
}
// dragHelper = document.createElement('DIV');
// dragHelper.style.cssText = 'position:absolute;display:none;';
// document.body.appendChild(dragHelper);
}
//-->
</SCRIPT>
</HTML>
<HEAD>
<TITLE>仿Google和Windows Live的拖拽</TITLE>
<style type="text/css">
body
{
margin:10px;
}
#dragHelper
{
position:absolute;/*重要*/
border:2px dashed #000000;
background-color:#FFFFFF;
filter: alpha(opacity=30);
}
.normal
{
position:absolute;/*重要*/
width:300px;
#height:10px;
border:1px solid #666666;
background-color:#FFFFFF;
}
.over
{
position:absolute;/*重要*/
width:300px;
#height:10px;
border:1px solid #666666;
background-color:#f3f3f3;
filter: alpha(opacity=50);
}
.dragArea {
CURSOR: move;
}
</style>
</HEAD>
<BODY oncontextmenu="window.event.returnValue=false">
<input type="text" id="evt" name="eventValue" size="40" />
<div id="dragHelper" style="display:none"></div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td><a href="#">baidu.com</a></td><td dragArea="yes" class="dragArea">........</td><td><a href="#"
onclick="openClose(this)">-</a> x</td></tr>
<tr><td colspan="3">地址:http://www.baidu.com</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td>新浪</td><td dragArea="yes" class="dragArea">........</td><td><a href="#" onclick="openClose(this)">-</a>
x</td></tr>
<tr><td colspan="3">地址:http://www.sina.com.cn</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td>好搜</td><td dragArea="yes" class="dragArea">........</td><td><a href="#" onclick="openClose(this)">-</a>
x</td></tr>
<tr><td colspan="3">地址:http://www.haosou.com</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div class="normal" overClass="over" dragClass="normal">
<table width="100%">
<tbody>
<tr bgcolor="#CCCCCC" bar="yes"><td>QQ</td><td dragArea="yes" class="dragArea">........</td><td><a href="#" onclick="openClose(this)">-</a>
x</td></tr>
<tr><td colspan="3">地址:http://www.qq.com</td></tr>
<tr><td colspan="3">關鍵字:</td></tr>
<tr><td colspan="3">說明:</td></tr>
</tbody>
</table>
</div>
<div><A href="http://www.999jiujiu.com/">http://www.999jiujiu.com/</A></div>
</BODY>
<SCRIPT LANGUAGE="JavaScript">
<!--
var dragObjs = [];//可以拖拽的元素陣列
var dragObjTops = [];
var dragHelper = document.getElementById("dragHelper");//拖拽時位置框
var dragObj = null;//拖拽物件元素
var dragObjPos = 0;
var dragObjOffset = {left:0,top:0};//拖拽物件原始位置
var mouseInDragObjOffset = {x:0,y:0};//滑鼠在拖拽物件中的相對位置
var initHeight = 40;
Number.prototype.NaN0=function(){return isNaN(this)?0:this;}
function getPosition(e){//獲取元素相對文件的絕對位置
var left = 0;
var top = 0;
while (e.offsetParent){
left += e.offsetLeft;
top += e.offsetTop;
e = e.offsetParent;
}
left += e.offsetLeft;
top += e.offsetTop;
return {x:left, y:top};
}
function mouseCoords(ev){//獲取滑鼠相對文件的絕對位置
if(ev.pageX || ev.pageY){
return {x:ev.pageX, y:ev.pageY};
}
return {
x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,
y:ev.clientY + document.body.scrollTop - document.body.clientTop
};
}
function getMouseOffset(target, ev){//獲取滑鼠相對元素的相對位置
ev = ev || window.event;
var elementPos = getPosition(target);
var mousePos = mouseCoords(ev);
return {x:mousePos.x - elementPos.x, y:mousePos.y - elementPos.y};
}
function mouseDown(ev){
ev = ev || window.event;
target = ev.srcElement || ev.target;
if(dragObj){
return;
}
var dragArea = false;
if(target.getAttribute("dragArea")){
dragArea = true;
}
while(!target.getAttribute("isDragObj")){
if(target.tagName=="HTML")
break;
target = target.parentNode;
}
if(dragArea && target.getAttribute("isDragObj")){
dragObj = target;
//重寫的目的是讓當前物件在最上層
document.body.removeChild(dragObj);
document.body.appendChild(dragObj);
//記錄下拖拽物件原始位置
dragObjOffset.left = dragObj.style.left;
dragObjOffset.top = dragObj.style.top;
dragObj.className = dragObj.getAttribute("overClass");
//滑鼠在拖拽物件中的相對位置
mouseInDragObjOffset = getMouseOffset(dragObj, ev);
dragHelper.style.left = dragObj.style.left;
dragHelper.style.top = dragObj.style.top;
dragHelper.style.width = dragObj.offsetWidth;
dragHelper.style.height = dragObj.offsetHeight;
dragHelper.style.display = "";
//alert(dragObj.offsetWidth+":"+dragObj.clientWidth);
}
}
function mouseUp(ev){
ev = ev || window.event;
target = ev.srcElement || ev.target;
if(dragObj){
dragObj.style.left = dragHelper.style.left;
dragObj.style.top = dragHelper.style.top;
dragHelper.style.display = "none";
dragObj.className = dragObj.getAttribute("dragClass");
dragObj = null;
}
}
function mouseMove(ev){
ev = ev || window.event;
if(dragObj) {
var mousePos = mouseCoords(ev);
/*dragHelper.style.left = dragObjOffset.left;
dragHelper.style.top = dragObjOffset.top;
dragHelper.style.width = dragObj.offsetWidth;
dragHelper.style.height = dragObj.offsetHeight;
dragHelper.style.display = "";*/
var windowWidth = document.body.offsetWidth;//視窗寬度
var windowHeight = document.body.offsetHeight;//視窗高度
//拖拽物件應該所在當前位置
var dragObjLeft = mousePos.x - mouseInDragObjOffset.x;
var dragObjTop = mousePos.y - mouseInDragObjOffset.y;
//增加判斷,不然拖拽物件拖出瀏覽器視窗
if(dragObjLeft >= 0 && dragObjLeft <= windowWidth - dragObj.offsetWidth - 20)
dragObj.style.left = dragObjLeft;
if(dragObjTop >=0)
dragObj.style.top = dragObjTop;
repaint();
}
}
//克隆物件
function cloneObject(srcObj, destObj){
destObj = srcObj.cloneNode(true);
}
function makeDraggable(element){
element.setAttribute("isDragObj", "y");
}
function repaint(){
for(i=0; i<dragObjs.length; i++){
if(dragObjs[i] == dragObj){
dragObjPos = i;
dragObjs[i] = dragHelper;
break;
}
}
if(dragObjPos>0 && parseInt(dragObj.style.top)<parseInt(dragObjs[dragObjPos-1].style.top)){
dragObjs[dragObjPos] = dragObjs[dragObjPos-1];
dragObjs[dragObjPos-1] = dragHelper;
dragObjPos = dragObjPos - 1;
}
if(dragObjPos<dragObjs.length-1 && parseInt(dragObj.style.top)>parseInt(dragObjs[dragObjPos+1].style.top)){
dragObjs[dragObjPos] = dragObjs[dragObjPos+1];
dragObjs[dragObjPos+1] = dragHelper;
dragObjPos = dragObjPos + 1;
}
paintDragObjs();
dragObjs[dragObjPos] = dragObj;
}
function paintDragObjs(){
var h = 40;
for(i=0; i<dragObjs.length; i++){
dragObjs[i].style.left = 20;
dragObjs[i].style.top = h;
h += dragObjs[i].offsetHeight + 10;
}
}
function openClose(obj){
obj.innerHTML = obj.innerHTML=="-"?"+":"-";
while(obj.tagName != "TBODY"){
obj = obj.parentNode;
}
for(i=0; i<obj.childNodes.length; i++){
if(obj.childNodes[i].nodeName == "#text"
|| obj.childNodes[i].getAttribute("bar")){ continue; }
obj.childNodes[i].style.display=obj.childNodes[i].style.display==""?"none":"";
}
paintDragObjs();
}
document.onmousedown = mouseDown;
document.onmouseup = mouseUp;
document.onmousemove = mouseMove;
window.onload = function(){
var objs = document.getElementsByTagName("Div");
for(i=0; i<objs.length; i++){
var item = objs.item(i);
//if(i==1)item.style.height=150;
if(item.getAttribute("overClass")){
makeDraggable(item);
dragObjs.push(item);
item.style.left = 20;
item.style.top = initHeight;
dragObjTops.push(initHeight);
initHeight += item.offsetHeight + 10;
}
}
// dragHelper = document.createElement('DIV');
// dragHelper.style.cssText = 'position:absolute;display:none;';
// document.body.appendChild(dragHelper);
}
//-->
</SCRIPT>
</HTML>
相關文章
- iGoogle的模組拖動層拖動Go
- JS實現拖動div層移動JS
- 特強的的拖動分頁(JS+CSSJSCSS
- 仿知乎拖動廣告的實現iOSiOS
- jQuery的ztree仿windows檔案新建和拖拽效果jQueryWindows
- (六)仿QQ首頁drawer/側滑刪除/浮動imgaeView/角標拖拽View
- 可拖動模組控制元件控制元件
- HTML元素拖動JSHTMLJS
- Js無重新整理新增新層,拖動DIV層可互換位置的JavaScript實現JSJavaScript
- jquery div層拖動效果封裝jQuery封裝
- vueusejs實現拖動VueJS
- Windows拖動選單揭密 (轉)Windows
- MultiItem擴充套件 仿任務皮膚 跨多個RecyclerView的Item拖動 支援縮小後拖動套件View
- vue仿layer.js彈層元件vlayerVueJS元件
- js 滾輪控制圖片縮放大小和拖動JS
- 靜態網頁和動態網頁的區別網頁
- Flutter 可拖拽的層疊卡片Flutter
- jQuery拖拽的彈出層效果jQuery
- 移動端觸屏拖動頁面滾動效果
- elementui 當表格有固定列,拖動條在固定列的範圍內時拖拽不動UI
- js拖動調整元素寬度JS
- jQuery實現的自定義可以拖動的彈出層效果jQuery
- 拖動滾動條實現網頁內容自動載入程式碼例項網頁
- 仿網易雲和支付寶首頁巢狀滑動巢狀
- asp.net,網頁層與div的資料互動ASP.NET網頁
- vue 網頁版聊天系統|仿微信、微博網頁端Vue網頁
- Jsp動態網頁開發JS網頁
- js拖拽技能JS
- js實現的div拖動效果例項程式碼JS
- js模組化之自定義模組(頁面模組化載入)JS
- js滑鼠拖動立方體3D運動效果JS3D
- js網頁圖片每日自動更新JS網頁
- 在網頁裡動態載入 js網頁JS
- js實現手機網頁滑動JS網頁
- javascript實現拖拽並替換網頁塊元素JavaScript網頁
- wordpress企業網站主題仿製02-wordpress企業網站首頁的仿製網站
- js拖動滑塊瀏覽圖片功能JS
- CommonJS模組 和 ECMAScript模組JS