




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第使用JavaScript實(shí)現(xiàn)一個(gè)拖拽縮放效果目錄前言基本思路拖拽實(shí)現(xiàn)縮放實(shí)現(xiàn)最后
前言
在寫一個(gè)簡(jiǎn)單的H5頁(yè)面時(shí),需要實(shí)現(xiàn)如下的一個(gè)拖拽效果,找了半天未能找到符合要求的,含淚手寫
先來(lái)看一下我們要是實(shí)現(xiàn)一個(gè)怎樣的效果
基本思路
鼠標(biāo)摁下,記錄元素的初始位置以及寬高監(jiān)聽鼠標(biāo)的移動(dòng),根據(jù)鼠標(biāo)的移動(dòng)不斷改變自己的位置/寬高是否存在邊界限制
拖拽實(shí)現(xiàn)
我們常見的改變?cè)匚恢玫姆绞接?/p>
定位使用translate進(jìn)行偏移
那我們現(xiàn)在用那種方式那實(shí)現(xiàn)拖拽呢?
從功能實(shí)現(xiàn)上來(lái)看,這兩個(gè)方式都能很好的實(shí)現(xiàn)我們的需求
從性能上來(lái)看,translate天生就是用來(lái)制作動(dòng)畫效果的,所以translate的性能以及流暢度都是要優(yōu)于定位的。
開始操作??!
style
.box{
margin:50px;
width:500px;
height:300px;
border:1pxsolidblack;
position:relative;
.drag{
height:100px;
width:100px;
background-color:#cbd;
/style
div
div/div
/div
script
letdragEl=document.querySelector(".drag")
letcontainer=document.querySelector(".box")
letwidth,height,maxWidth,maxHeight,tx,ty,startX,startY
//初始化
functioninit(){
//為目標(biāo)元素設(shè)置初始的偏移,避免在第一次獲取偏移時(shí)為空的問(wèn)題
dragEl.style.transform="translate(0px,0px)"
//獲取父元素寬高
maxWidth=container.clientWidth
maxHeight=container.clientHeight
functiongetInfo(e){
//獲取元素當(dāng)前的寬高
width=dragEl.clientWidth
height=dragEl.clientHeight
//獲取元素當(dāng)前的偏移量
lettranslateStr=dragEl.style.transform
constreg=/\d+/g
lettranslateArr=translateStr.match(reg)
tx=Number(translateArr[0])
ty=Number(translateArr[1])
//記錄鼠標(biāo)的起始位置
startX=e.clientX
startY=e.clientY
functiondrag(){
dragEl.addEventListener("mousedown",(e)={
getInfo(e)
document.onmousemove=(e)={
letdistanceX=tx+e.clientX-startX
letdistanceY=ty+e.clientY-startY
dragEl.style.transform=`translate(${distanceX}px,${distanceY}px)`
document.onmouseup=()={
document.onmousemove=null
init()
drag()
/script
通過(guò)上述代碼,我們已經(jīng)完成了元素的拖動(dòng),接下來(lái)需要考慮的就是,如果有邊界限制,我們又該如何實(shí)現(xiàn)
從上訴例子中,我們可以觀察出,元素偏移的最小值為0,最大值為父元素的寬高-目標(biāo)元素的寬高
所以在有邊界限制的情形下偏移量的計(jì)算方式為
letdistanceX=Math.max(0,Math.min(tx+e.clientX-startX,maxWidth-width))
letdistanceY=Math.max(0,Math.min(ty+e.clientY-startY,maxHeight-height))
縮放實(shí)現(xiàn)
這里我們以向左縮放為例
首先我們需要為目標(biāo)元素添加一個(gè)邊框,用來(lái)進(jìn)行縮放的操作
style
.box{
margin:50px;
width:500px;
height:300px;
border:1pxsolidblack;
position:relative;
.drag{
height:100px;
width:100px;
background-color:#cbd;
.left{
width:10px;
height:calc(100%-14px);
margin:7px0px;
position:absolute;
background-color:#000;
cursor:col-resize;
top:0;
left:-5px;
/style
script
functionaddLeft(){
left=document.createElement("div")
left.className="left"
dragEl.append(left)
init()
drag()
addLeft()
/script
2.為左側(cè)的邊框添加縮放功能,因?yàn)槭亲髠?cè)的縮放,所以在寬度變化的同時(shí),需要不斷調(diào)整元素的位置,令其符合視覺(jué)效果
functionleftZoom(){
left.addEventListener("mousedown",(e)={
e.stopPropagation()
getInfo(e)
document.onmousemove=(e)={
//注意這里是?
newWidth=width-(e.clientX-startX)
letdistanceX=tx+(e.clientX-startX)
dragEl.style.width=`${newWidth}px`
dragEl.style.transform=`translate(${distanceX}px,${ty}px)`
document.onmouseup=()={
document.onmousemove=null
init()
drag()
addLeft()
leftZoom()
限制元素縮放的最小值
letminWidth=30
newWidth=Math.max(minWidth,width-(e.clientX-startX))
現(xiàn)在我們已經(jīng)完成了縮放,但是當(dāng)元素向右縮小到最小值時(shí),元素會(huì)向右移動(dòng),顯然這是不符合邏輯的,所以我們需要對(duì)偏移進(jìn)行限制
//最大偏移為已經(jīng)偏移的距離+目標(biāo)元素的寬度-最小寬度
letdistanceX=Math.min(tx+width-minWidth,tx+(e.clientX-startX))
4.如果縮放的尺寸需要限制在父元素內(nèi),我們需要繼續(xù)完善代碼
//最大寬度為元素當(dāng)前偏移量+最初的寬度,最小寬度為minWidth
newWidth=Math.min(tx+width,Math.max(minWidth,width-(e.clientX-startX)))
//最大偏移為已經(jīng)偏移的距離+目標(biāo)元素的寬度-最小寬度,最小偏移為0
letdistanceX=Math.max(0,Math.min(tx+width-minWidth,tx
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 員工防疫小知識(shí)培訓(xùn)總結(jié)課件
- 吸毒知識(shí)培訓(xùn)內(nèi)容記錄課件
- 如何引入概率課件
- 考點(diǎn)解析-四川省峨眉山市中考數(shù)學(xué)真題分類(平行線的證明)匯編同步練習(xí)試題(含解析)
- 城市社區(qū)建設(shè)與服務(wù)提升
- 遼寧鞍山市教育局面向2025屆畢業(yè)生校園招聘教師23人筆試備考題庫(kù)及完整答案詳解1套
- 虛擬現(xiàn)實(shí)運(yùn)動(dòng)障礙康復(fù)-洞察及研究
- 寧波市公安局招聘警務(wù)輔助人員的筆試高頻難、易錯(cuò)點(diǎn)備考題庫(kù)及參考答案詳解
- 2025年事業(yè)單位筆試-福建-福建中醫(yī)臨床(醫(yī)療招聘)歷年參考題庫(kù)典型考點(diǎn)含答案解析
- 2026屆福建省漳州第一中學(xué)高二化學(xué)第一學(xué)期期中調(diào)研模擬試題含解析
- 生產(chǎn)經(jīng)理薪資協(xié)議書
- 達(dá)州國(guó)企面試題及答案
- 群團(tuán)工作筆試試題及答案
- 英語(yǔ)口語(yǔ)8000句精裝版2
- 中等職業(yè)學(xué)校數(shù)字媒體技術(shù)應(yīng)用專業(yè)人才培養(yǎng)方案
- 倉(cāng)儲(chǔ)管理賦能培訓(xùn)
- 高一上學(xué)期《早讀是需要激情的!》主題班會(huì)課件
- 龍門吊警示教育
- 食堂購(gòu)買蔬菜管理制度
- (二模)金華十校2025年4月高三模擬考試語(yǔ)文試卷(含答案解析)
- 油畫修復(fù)技術(shù)探討-深度研究
評(píng)論
0/150
提交評(píng)論