使用Vue2怎么實現一個圖片上傳、壓縮、拖拽排序等功能?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
圖片上傳
圖片上傳用的是HTML的input標簽實現的。核心就是把獲取到的文件通過FileReader轉換成圖片,代碼如下:
<input type="file" accept="image/*" capture="camera" @change="selectFile">
selectFile(event:any){
this.showAlert = false
if (event.target.files && event.target.files.length > 0) {
this.isLoading = true
let file:any = event.target.files[0]
let fr:any = new FileReader()
fr.readAsDataURL(file)
fr.onload = (imgObj:any) => {
let img:any = new Image()
img.src = imgObj.target.result
img.onload = (e:any) => {
// 這里就可以獲取到上傳的圖片了
})
}
}
}
}圖片壓縮用的是canvas重繪的方法實現的,具體代碼如下:
// 省略上面的代碼
fr.onload = (imgObj:any) => {
// 獲取到圖片文件后
let img:any = new Image()
img.src = imgObj.target.result
img.onload = (e:any) => {
Compress(img,e.path[0].height,e.path[0].width,(newImg:any) => {
this.imgList.push(newImg)
this.isLoading = false
// 待添加拖拽功能
})
}
}
/**
* 圖片壓縮
* @param img 圖片對象
*/
export function Compress(img:any,height:number,width:number,callback:Function) {
let canvas:any = document.createElement('canvas')
let context:any = canvas.getContext('2d')
canvas.width = width
canvas.height = height
context.clearRect(0,0,width,height)
context.drawImage(img,0,0,width,height)
callback(canvas.toDataURL("image/jpeg", 0.75))
}拖拽排序、拖拽到指定位置刪除是通過監聽touch事件來實現的。
核心思路:
1、獲取到圖片dom元素,給圖片dom元素添加ontouchstart、ontouchend、ontouchmove 方法。
2、在ontouchstart方法中new一個時間節點,在ontouchend中也new一個時間節點,通過判斷兩個時間節點之間的時間間隔判斷是點擊事件還是長按事件。
3、ontouchstart中設置settimeout方法是延時判斷是點擊方法還是長按方法,如果是長按方法的則獲取圖片的所在頁面中的位置,設置圖片的位置為點擊屏幕的位置,改變圖片的布局方式,在ontouchmove方法中設置圖片的位置跟隨觸摸屏幕的位置變化。
4、移動圖片后松開手時,觸發ontouchend方法,判斷手指離開后,圖片所在的位置是否處在刪除的區域當中,如果在則刪除圖片,并且重新渲染圖片列表,重新添加touch方法。
如果不在刪除的區域中,則進行圖片位置排序,排序后還原圖片樣式。并強制重新渲染圖片列表。
代碼如下:
Compress(img,e.path[0].height,e.path[0].width,(newImg:any) => {
this.imgList.push(newImg)
this.isLoading = false
// 在這里給加入方法
setTimeout(() => {
this.addTouchEvent()
});
})
addTouchEvent(){
let domList:any = document.querySelectorAll('.show-img')
if (domList) {
let domMoveFlag:boolean = true
domList.forEach((item:any,index:any) => {
item.ontouchstart = null
item.ontouchmove = null
item.ontouchend = null
item.ontouchstart = (startEvent:any) => {
startEvent.preventDefault()
console.log(startEvent)
this.touchStartTime = new Date()
setTimeout(() => {
if (domMoveFlag) {
console.log('執行元素位置操作過程')
this.showDeleteArea = true
let domClient:any = item.getBoundingClientRect()
console.log(domClient)
this.firstPosition = {
x:startEvent.changedTouches[0].pageX,
y:startEvent.changedTouches[0].pageY
}
item.style.position = 'fixed'
item.style.height = domClient.height + 'px'
item.style.width = domClient.width + 'px'
item.style.top = domClient.top + 'px'
item.style.left = domClient.left + 'px'
item.style.padding = 0
item.style.zIndex = 9
// 添加拖拽事件
item.ontouchmove = (moveEvent:any) => {
// console.log(moveEvent)
item.style.top = moveEvent.changedTouches[0].pageY - this.firstPosition.y + domClient.top + 'px'
item.style.left = moveEvent.changedTouches[0].pageX - this.firstPosition.x + domClient.left + 'px'
}
}
}, 600);
}
item.ontouchend = (endEvent:any) => {
let time:any = new Date()
console.log(time - this.touchStartTime)
if (time - this.touchStartTime <= 400) {
domMoveFlag = false
item.click()
setTimeout(() => {
this.addTouchEvent()
});
} else {
let newItemCenter:any = item.getBoundingClientRect()
let centerY:any = newItemCenter.top + newItemCenter.height / 2
let centerX:any = newItemCenter.left + newItemCenter.width / 2
let deleteDom:any = document.querySelector(".deleteImg")
let deleteArea:any = deleteDom.getBoundingClientRect()
if (centerY >= deleteArea.top) {
let _imgList = JSON.parse(JSON.stringify(this.imgList))
let currentImg:any = _imgList.splice(index,1)
this.imgList = []
this.showDeleteArea = false
setTimeout(() => {
this.imgList = _imgList
setTimeout(() => {
this.addTouchEvent()
});
});
return
}
this.showDeleteArea = false
// 計算所有圖片元素所在頁面位置
let domParentList:any = document.querySelectorAll('.imgCtn')
domParentList && domParentList.forEach((domParent:any,cindex:any) => {
let domPos:any = (domParent.getBoundingClientRect())
if (
centerY >= domPos.top
&& centerY <= domPos.bottom
&& centerX >= domPos.left
&& centerX <= domPos.right
) {
// 重新排序
console.log('在目標區域內,重新排序')
let _imgList = JSON.parse(JSON.stringify(this.imgList))
let currentImg:any = _imgList.splice(index,1)
_imgList.splice(cindex,0,...currentImg)
this.imgList = []
setTimeout(() => {
this.imgList = _imgList
setTimeout(() => {
this.addTouchEvent()
});
});
}
});
// 還原樣式
item.style.position = 'absolute';
item.style.height = '100%'
item.style.width = '100%'
item.style.top = '0'
item.style.left = '0'
item.style.padding = '10px'
}
}
})
}
}關于使用Vue2怎么實現一個圖片上傳、壓縮、拖拽排序等功能問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。