仿Google和Windows Live的拖拽

來源:互聯網
上載者:User
提示:您可以先修改部分代碼再運行

<HTML><HEAD><TITLE> New Document </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" ></div><div class="normal" overClass="over" dragClass="normal"><table width="100%"><tbody><tr bgcolor="#CCCCCC" bar="yes"><td>Cobao</td><td dragArea="yes" class="dragArea">........</td><td>- x</td></tr><tr><td colspan="3">地址:http://www.cobao.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>- 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>- x</td></tr><tr><td colspan="3">地址:http://www.163.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>- 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></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>
提示:您可以先修改部分代碼再運行
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.