js實現限定範圍拖拽的示例
阿新 • • 發佈:2020-10-27
限定範圍拖拽
目錄
- 程式碼例項
- 與簡易拖拽的差異
- 下載原始碼連結
程式碼例項
* { padding: 0; margin: 0; } #box1 { width: 500px; height: 500px; background: #999; position: relative; left: 100px; top: 100px; } #box { width: 100px; height: 100px; background: #334; position: absolute; cursor: move; } <div id="box1"> <div id="box"></div> </div> (function () { var dragging = false var boxX,boxY,mouseX,mouseY,offsetX,offsetY var box = document.getElementById('box') var box1 = document.getElementById('box1') // 滑鼠按下的動作 box.onmousedown = down // 滑鼠的移動動作 document.onmousemove = move // 釋放滑鼠的動作 document.onmouseup = up // 滑鼠按下後的函式,e為事件物件 function down(e) { dragging = true // 獲取元素所在的座標 boxX = box.offsetLeft boxY = box.offsetTop // 獲取滑鼠所在的座標 mouseX = parseInt(getMouseXY(e).x) mouseY = parseInt(getMouseXY(e).y) // 滑鼠相對元素左和上邊緣的座標 offsetX = mouseX - boxX offsetY = mouseY - boxY } // 滑鼠移動呼叫的函式 function move(e){ if (dragging) { // 獲取移動後的元素的座標 var x = getMouseXY(e).x - offsetX var y = getMouseXY(e).y - offsetY // 計算可移動位置的大小, 保證元素不會超過可移動範圍 // 此處就是父元素的寬度減去子元素寬度 var width = box1.clientWidth - box.offsetWidth var height = box1.clientHeight - box.offsetHeight // min方法保證不會超過右邊界,max保證不會超過左邊界 x = Math.min(Math.max(0,x),width) y = Math.min(Math.max(0,y),height) // 給元素及時定位 box.style.left = x + 'px' box.style.top = y + 'px' } } // 釋放滑鼠的函式 function up(e){ dragging = false } // 函式用於獲取滑鼠的位置 function getMouseXY(e){ var x = 0,y = 0 e = e || window.event if (e.pageX) { x = e.pageX y = e.pageY } else { x = e.clientX + document.body.scrollLeft - document.body.clientLeft y = e.clientY + document.body.scrollTop - document.body.clientTop } return { x: x,y: y } } })()
與簡易拖拽的差異
簡易拖拽的連結
可移動位置的改變
// 此處就是父元素的寬度減去子元素寬度 var width = box1.clientWidth - box.offsetWidth var height = box1.clientHeight - box.offsetHeight
下載原始碼連結
星輝的Github
以上就是js實現限定範圍拖拽的示例的詳細內容,更多關於js實現限定範圍拖拽的資料請關注我們其它相關文章!