JavaScript實(shí)現(xiàn)拖拽和縮放效果
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)拖拽和縮放效果的具體代碼,供大家參考,具體內(nèi)容如下
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>拖拽縮放</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<style>
* {
margin: 0;
padding: 0
}
#box {
width: 100%;
height: 100%;
position: relative;
background: #4bb0bb
}
#drag {
width: 200px;
height: 200px;
position: relative;
background: #691fff;
cursor: move;
}
#scale {
width: 20px;
height: 20px;
position: absolute;
background: #ffa500;
cursor: se-resize;
right: 0;
bottom: 0;
overflow: hidden;
}
</style>
<body>
<div id="box">
<div id="drag">
<div id="scale"></div>
</div>
</div>
</body>
<script>
window.onload = function () {
var box = document.getElementById("box")
var drag = document.getElementById("drag")
var scale = document.getElementById("scale")
// mousedown mousemove mouseup
dragTool(drag)
scaleTool(drag, scale, box)
// 拖拽方法
function dragTool(node) {
node.onmousedown = function (ev) {
// 瀏覽器兼容處理
var e = ev || window.event;
// 鼠標(biāo)按下記錄相對(duì)位置
// 水平方向都距離 = 當(dāng)前鼠標(biāo)左邊的距離 - 被拖拽元素距離左邊的距離
var offsetX = e.clientX - node.offsetLeft;
// 垂直方向都距離 = 當(dāng)前鼠標(biāo)都上邊的距離 - 被拖拽元素距離距離的距離
var offsetY = e.clientY - node.offsetTop;
// 鼠標(biāo)移動(dòng)和被拖拽的元素是相對(duì)的 這里是鼠標(biāo)拖拽的物體在整個(gè)頁面上移動(dòng) 所以
// move加在document上
document.onmousemove = function (ev) {
// 當(dāng)前鼠標(biāo)的事件對(duì)象
var e = ev || window.event;
// 定義 currentLeft = 當(dāng)前鼠標(biāo)位置 - 距離左邊的距離
var currentLeft = e.clientX - offsetX;
// 定義 currentTop = 當(dāng)前鼠標(biāo)上邊位置 - 距離上邊的距離
var currentTop = e.clientY - offsetY
// 限制左出界 最左是 0
if (currentLeft <= 0) {
currentLeft = 0;
}
// 當(dāng)前窗口的寬 瀏覽器兼容
var windowWidth = document.documentElement.clientWidth || document.body.clientWidth;
// 限制右邊出界 如果大于當(dāng)前窗口的寬 那么就讓它等于當(dāng)前窗口的寬減去當(dāng)前元素的offsetWidth 也就是留在原地
if (currentLeft >= windowWidth - node.offsetWidth) {
currentLeft = windowWidth - node.offsetWidth;
}
// 設(shè)置上出界 最上邊是 0
if (currentTop <= 0) {
currentTop = 0;
}
// 當(dāng)前窗口的高 瀏覽器兼容
var windowHeight = document.documentElement.clientHeight || document.body.clientHeight;
// 限制下邊出界 如果大于當(dāng)前窗口的高 減去 本身的高 那么就讓它等于 當(dāng)前窗口的高減去本身的高
if (currentTop >= windowHeight - node.offsetHeight) {
currentTop = windowHeight - node.offsetHeight;
}
// 當(dāng)前被拖拽元素的 left 值 等于上面計(jì)算出的 currentLeft
node.style.left = currentLeft + 'px';
// 當(dāng)前被拖拽元素的 top 值 等于上面計(jì)算出的 currentTop
node.style.top = currentTop + 'px';
}
}
// 鼠標(biāo)彈起取消拖拽 這里添加到 node 元素對(duì)象也可以的
document.onmouseup = function () {
document.onmousemove = null;
}
}
// 縮放
function scaleTool(drag, scale, box) {
scale.onmousedown = function (e) {
//阻止冒泡 避免縮放觸發(fā)移動(dòng)事件
e.stopPropagation()
// 取消事件的默認(rèn)動(dòng)作
e.preventDefault()
// 定義position
var position = {
'w': drag.offsetWidth, // 被縮放元素的offsetWidth
'h': drag.offsetHeight, // 被縮放元素的offsetHeight
'x': e.clientX, // 當(dāng)前窗口鼠標(biāo)指針的水平坐標(biāo)
'y': e.clientY, // 當(dāng)前窗口鼠標(biāo)指針的垂直坐標(biāo)
}
drag.onmousemove = function (ev) {
ev.preventDefault()
// 設(shè)置最大縮放為30*30 Math.max取最大值
var w = Math.max(30, ev.clientX - position.x + position.w)
var h = Math.max(30, ev.clientY - position.y + position.h)
// 設(shè)置最大的寬高
w = w >= box.offsetWidth - drag.offsetLeft ? box.offsetWidth - drag.offsetLeft : w;
h = h >= box.offsetHeight - drag.offsetTop ? box.offsetHeight - drag.offsetTop : h;
drag.style.width = w + 'px';
drag.style.height = h + 'px';
}
// 鼠標(biāo)離開和抬起取消縮放
drag.onmouseup = function () {
drag.onmousemove = null;
drag, onmouseup = null;
}
drag.onmouseleave = function () {
drag.onmousemove = null;
drag, onmouseup = null;
}
}
}
}
</script>
</html>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js 剪切板的用法(clipboardData.setData)與js match函數(shù)介紹
這篇文章主要是對(duì)js中剪切板的使用方法(clipboardData.setData)與js中的match函數(shù)進(jìn)行了介紹。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-11-11
JS實(shí)現(xiàn)點(diǎn)擊button按鈕切換圖片
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)點(diǎn)擊button按鈕切換圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
JS打開圖片另存為對(duì)話框?qū)崿F(xiàn)代碼
使用JS打開圖片另存為對(duì)話框一直都是網(wǎng)頁應(yīng)用中不可缺少的一部分,本人有些好奇,于是搜集整理了一些實(shí)現(xiàn)代碼,不知道符不符合大眾的口味,在此班門弄斧了,需要的朋友可以了解下2012-12-12
JS仿京東移動(dòng)端手指撥動(dòng)切換輪播圖效果
這篇文章主要為大家詳細(xì)介紹了JS仿京東移動(dòng)端手指撥動(dòng)切換輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
js獲取html頁面節(jié)點(diǎn)方法(遞歸方式)
這篇文章主要介紹了js使用遞歸方式獲取html頁面節(jié)點(diǎn)的方法,大家可以參考使用吧2013-12-12
Vue+ElementUI實(shí)現(xiàn)文件照片音頻視頻預(yù)覽功能
這篇文章主要介紹了JavaScript代碼實(shí)現(xiàn)微博批量取消關(guān)注功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
基于Bootstrap實(shí)現(xiàn)Material Design風(fēng)格表單插件 附源碼下載
Jquery Material Form Plugin是一款基于Bootstrap的Material Design風(fēng)格的jQuery表單插件。這篇文章主要介紹了基于Bootstrap的Material Design風(fēng)格表單插件附源碼下載,感興趣的朋友參考下2016-04-04

