仿Google和Windows Live的拖拽_javascript技巧

來源:互聯網
上載者: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>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.