大型网站 开发语言,画册什么网站做方便,wordpress主题模版,wordpress文章页设置说在前面 #x1f5bc;文件拖拽上传功能现在已经随处可见#xff0c;大家应该都用过了吧#xff0c;那么它具体是怎么实现的大家有去了解过吗#xff1f;今天我们一起来实现一下这个功能#xff0c;并封装一个拖拽上传组件吧。 效果展示 体验地址#xff1a;http://jyeon…说在前面 文件拖拽上传功能现在已经随处可见大家应该都用过了吧那么它具体是怎么实现的大家有去了解过吗今天我们一起来实现一下这个功能并封装一个拖拽上传组件吧。 效果展示 体验地址http://jyeontu.xyz/jvuewheel/#/JDragUploadView
功能实现
原生JavaScrip实现
首先我们应该先将页面写好
!DOCTYPE html
html langenheadtitle点击或拖拽上传并显示图片/titlestylebody {display: flex;flex-direction: column;}h1 {text-align: center;}#drop-zone {width: 300px;height: 200px;border: 2px dashed #ccc;margin: 20px auto;text-align: center;line-height: 200px;font-size: 18px;}#uploaded-image {max-width: 300px;max-height: 300px;margin: 20px auto;}/style/headbodyh1点击或拖拽上传并显示图片示例/h1div iddrop-zone点击或拖拽上传图片/divimg iduploaded-image src alt上传的图片 /script/script/body
/html我们试下直接拖拽图片到页面上是什么效果 我们发现直接将图片拖拽到页面上会在新页面打开图片那么我们需要阻止这一个默认行为以允许放置页面的拖拽行为主要会触发以下几个事件
dragenter
dragenter 事件在可拖动的元素或者被选择的文本进入一个有效的放置目标时触发。
目标对象是用户直接选择的范围由用户直接指示作为放置目标的元素或者 body 元素。
dragleave
dragleave 事件在拖动的元素或选中的文本离开一个有效的放置目标时被触发。
此事件不可取消。
dragover
dragover 事件在可拖动的元素或者被选择的文本被拖进一个有效的放置目标时每几百毫秒触发。
该事件在放置目标上触发。
drop
drag 事件在用户拖动元素或选择的文本时每隔几百毫秒就会被触发一次。
效果实现
获取上传框和预览框元素
const dropZone document.getElementById(drop-zone);
const uploadedImage document.getElementById(uploaded-image);图片进入上传框时为上传框加一层灰色蒙层
监听上传框的dragenter事件在图片移动进入上传框时改变上传框的背景颜色。
dropZone.addEventListener(dragenter, function (event) {dropZone.style.backgroundColor #f7f7f7;
});图片离开上传框时去除上传框的灰色蒙层
监听上传框的dragleave事件在图片移出上传框时去除上传框的背景颜色。
dropZone.addEventListener(dragleave, function (event) {dropZone.style.backgroundColor ;
});阻止浏览器默认行为例如打开文件
dragover和drop事件都会触发浏览器打开文件我们需要阻止其默认行为。
dropZone.addEventListener(dragover, function (event) {event.preventDefault();
});
dropZone.addEventListener(drop, function (event) {event.preventDefault();
});获取拖拽上传的文件
拖拽释放会触发drop事件我们只需要监听drop事件获取到拖拽的文件列表event.dataTransfer.files即可。
dropZone.addEventListener(drop, function (event) {event.preventDefault();dropZone.style.backgroundColor ;const file event.dataTransfer.files[0];handleFile(file);
});处理上传文件为图片时设置预览图
判断上传的文件是否为图片我们只需要判断上传文件的type是否为image开头是的话我们可以将其转为dataUrl文件并设置预览。 function handleFile(file) {if (file file.type.startsWith(image/)) {const reader new FileReader();reader.onload function (event) {uploadedImage.src event.target.result;};reader.readAsDataURL(file);}}封装为vue组件
知道了原生js实现一个拖拽上传功能之后我们也能很容易得将其封装成一个vue组件。
监听拖拽事件
在vue中我们直接通过dragover、dragleave、drop即可监听元素的拖拽事件。
divclassupload-areadragover.preventhandleDragOverdragleavehandleDragLeavedrop.preventhandleDropclickhandleUploadClick
p v-if!isDragging classtip-text{{ tipText }}/pp v-else{{ tipConfirmText }}/p
/div事件的处理逻辑和原生js其实都是一样的。
methods: {handleDragOver(event) {event.preventDefault();this.isDragging true;},handleDragLeave() {this.isDragging false;},handleDrop(event) {event.preventDefault();this.isDragging false;const file event.dataTransfer.files[0];this.uploadFile(file);}
}获取到上传文件并传递给父组件
获取到上传的文件后我们不应该组件内直接处理文件了将其传递给父组件进行处理即可。
uploadFile(file) {this.$emit(uploadFile, file);
}组件完整代码
功能逻辑与原生JavaScrip基本相同这里也不重复描述了直接看代码吧
templatediv classdrag-uploaddivclassupload-areadragover.preventhandleDragOverdragleavehandleDragLeavedrop.preventhandleDropclickhandleUploadClickp v-if!isDragging classtip-text{{ tipText }}/pp v-else{{ tipConfirmText }}/p/divinputtypefilereffileInputstyledisplay: nonechangehandleFileSelected//div
/templatescript
export default {name: JDragUpload,props: {tipText: {type: String,default: 将文件拖放到此处或点击上传,},tipConfirmText: {type: String,default: 释放文件以上传,},},data() {return {isDragging: false,};},methods: {handleDragOver(event) {event.preventDefault();this.isDragging true;},handleDragLeave() {this.isDragging false;},handleDrop(event) {event.preventDefault();this.isDragging false;const file event.dataTransfer.files[0];this.uploadFile(file);},handleUploadClick() {this.$refs.fileInput.click();},handleFileSelected() {const file this.$refs.fileInput.files[0];this.uploadFile(file);},uploadFile(file) {this.$emit(uploadFile, file);},},
};
/scriptstyle langless scoped
.drag-upload {display: flex;align-items: center;justify-content: center;height: 100%;width: 100%;border: 2px dashed #ccc;.upload-area {display: flex;align-items: center;justify-content: center;height: 100%;width: 100%;background-color: #f0f0f0;cursor: pointer;.tip-text {text-align: center;}}
}
/style源码
组件体验及文档地址http://jyeontu.xyz/jvuewheel/#/JDragUploadView
Gitee源码https://gitee.com/zheng_yongtao/jyeontu-component-warehouse/tree/master/JYeontuComponentWarehouse/packages/JDragUpload
说在后面 这里是 JYeontu现在是一名前端工程师有空会刷刷算法题平时喜欢打羽毛球 平时也喜欢写些东西既为自己记录 也希望可以对大家有那么一丢丢的帮助写的不好望多多谅解 写错的地方望指出定会认真改进 偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章有兴趣的也可以关注下。在此谢谢大家的支持我们下文再见 。