JS實(shí)現(xiàn)基于拖拽改變物體大小的方法
本文實(shí)例講述了JS實(shí)現(xiàn)基于拖拽改變物體大小的方法。分享給大家供大家參考,具體如下:
拖拽改變物體大小功能:拖拽黃色小div來(lái)改變綠色大div的寬和高

主要實(shí)現(xiàn)由三大步:
1. 通過(guò)id獲取到大小兩個(gè)div
2. 給小div添加onmousedown事件
3. 在onmousedown事件給document添加onmousemove和onmouseup事件

由分析圖可知,我們只需要在拖拽的時(shí)候,獲取到物體不斷增加的寬度值,問(wèn)題就解決了
<div id="panel"> <div id="dragIcon"></div> </div>
加些樣式
<style>
#panel{
position: absolute;
width: 200px;height: 200px;
background: green;
}
#dragIcon{
position: absolute;bottom: 0;right: 0;
width: 20px;height: 20px;
background: yellow;
}
</style>
js實(shí)現(xiàn)代碼:
<script>
window.onload = function () {
// 1. 獲取兩個(gè)大小div
var oPanel = document.getElementById('panel');
var oDragIcon = document.getElementById('dragIcon');
// 定義4個(gè)變量
var disX = 0;//鼠標(biāo)按下時(shí)光標(biāo)的X值
var disY = 0;//鼠標(biāo)按下時(shí)光標(biāo)的Y值
var disW = 0; //拖拽前div的寬
var disH = 0; // 拖拽前div的高
//3. 給小div加點(diǎn)擊事件
oDragIcon.onmousedown = function (ev) {
var ev = ev || window.event;
disX = ev.clientX; // 獲取鼠標(biāo)按下時(shí)光標(biāo)x的值
disY = ev.clientY; // 獲取鼠標(biāo)按下時(shí)光標(biāo)Y的值
disW = oPanel.offsetWidth; // 獲取拖拽前div的寬
disH = oPanel.offsetHeight; // 獲取拖拽前div的高
document.onmousemove = function (ev) {
var ev = ev || window.event;
//拖拽時(shí)為了對(duì)寬和高 限制一下范圍,定義兩個(gè)變量
var W = ev.clientX - disX + disW;
var H = ev.clientY - disY + disH;
if(W<100){
W = 100;
}
if(W>800){
W =800;
}
if(H<100){
H = 100;
}
if(H>500){
H = 500;
}
oPanel.style.width =W +'px';// 拖拽后物體的寬
oPanel.style.height = H +'px';// 拖拽后物體的高
}
document.onmouseup = function () {
document.onmousemove = null;
document.onmouseup = null;
}
}
}
</script>
效果圖:

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript動(dòng)畫(huà)特效與技巧匯總》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript中json操作技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JS實(shí)現(xiàn)的簡(jiǎn)單拖拽購(gòu)物車(chē)功能示例【附源碼下載】
- AngularJS實(shí)現(xiàn)的簡(jiǎn)單拖拽功能示例
- 使用javaScript實(shí)現(xiàn)鼠標(biāo)拖拽事件
- js實(shí)現(xiàn)QQ面板拖拽效果(慕課網(wǎng)DOM事件探秘)(全)
- js實(shí)現(xiàn)鼠標(biāo)拖拽多選功能示例
- js實(shí)現(xiàn)拖拽上傳圖片功能
- 完美實(shí)現(xiàn)js拖拽效果 return false用法詳解
- 簡(jiǎn)單實(shí)現(xiàn)js拖拽效果
- 基于AngularJS的拖拽文件上傳的實(shí)例代碼
- Java實(shí)現(xiàn)拖拽文件上傳dropzone.js的簡(jiǎn)單使用示例代碼
- JS實(shí)現(xiàn)簡(jiǎn)單拖拽效果
- JS實(shí)現(xiàn)簡(jiǎn)易的圖片拖拽排序?qū)嵗a
- js實(shí)現(xiàn)控制文件拖拽并獲取拖拽內(nèi)容功能
相關(guān)文章
JavaScript實(shí)現(xiàn)無(wú)阻塞加載的常用方式
在 JavaScript 中,無(wú)阻塞加載(Non-blocking Loading)是優(yōu)化網(wǎng)頁(yè)性能的關(guān)鍵技術(shù),通過(guò)避免腳本阻塞頁(yè)面渲染和其他資源的加載,提升用戶體驗(yàn),以下是實(shí)現(xiàn)無(wú)阻塞加載的常用方法及示例,需要的朋友可以參考下2025-03-03
js實(shí)現(xiàn)的類似于asp數(shù)據(jù)字典的數(shù)據(jù)類型代碼實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)的類似于asp數(shù)據(jù)字典的數(shù)據(jù)類型代碼實(shí)例,即js實(shí)現(xiàn)的字典數(shù)據(jù)類型,需要的朋友可以參考下2014-09-09
JavaScript實(shí)現(xiàn)數(shù)組去重的14種方法大全
親愛(ài)的小伙伴,對(duì)于數(shù)組javascript中的數(shù)組去重方法你知道多少種呢?學(xué)會(huì)如何對(duì)數(shù)組進(jìn)行去重對(duì)于javascript的學(xué)習(xí)來(lái)說(shuō)也是十分重要的,下邊就讓我來(lái)分享一下我所知道的集中數(shù)組去重的方法吧,感興趣的小伙伴跟著小編一起來(lái)看看吧2025-03-03
WebSocket連接頻繁斷開(kāi)的問(wèn)題及解決方案
隨著實(shí)時(shí)應(yīng)用的普及,如在線聊天、實(shí)時(shí)數(shù)據(jù)監(jiān)控和協(xié)作工具,WebSocket 成為了實(shí)現(xiàn)雙向通信的重要技術(shù),然而,在實(shí)際開(kāi)發(fā)中,開(kāi)發(fā)者常常會(huì)遇到 WebSocket 連接頻繁斷開(kāi)的情況,本文將深入探討 WebSocket 連接頻繁斷開(kāi)的常見(jiàn)原因,并提供詳細(xì)的解決方案和最佳實(shí)踐2025-02-02
微信小程序?qū)崿F(xiàn)的動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能示例
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能,結(jié)合實(shí)例形式分析了微信小程序使用wx.setNavigationBarTitle接口動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題的相關(guān)操作技巧,需要的朋友可以參考下2019-01-01
JavaScript實(shí)現(xiàn)一個(gè)輸入框組件
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)一個(gè)輸入框組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
簡(jiǎn)單聊聊JavaScript的事件循環(huán)機(jī)制
前端開(kāi)發(fā)的童鞋應(yīng)該都知道,JavaScript是一門(mén)單線程的腳本語(yǔ)言,這就意味著JavaScript 代碼在執(zhí)行的時(shí)候,只有一個(gè)主線程來(lái)執(zhí)行所有的任務(wù),同一個(gè)時(shí)間只能做同一件事情,這篇文章主要給大家介紹了關(guān)于JavaScript事件循環(huán)機(jī)制的相關(guān)資料,需要的朋友可以參考下2022-03-03

