当前位置: 首页 > news >正文

加盟代理网淮安网站seo

加盟代理网,淮安网站seo,青岛做网站建设多少钱,拷问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现在是一名前端工程师有空会刷刷算法题平时喜欢打羽毛球 平时也喜欢写些东西既为自己记录 也希望可以对大家有那么一丢丢的帮助写的不好望多多谅解 写错的地方望指出定会认真改进 偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章有兴趣的也可以关注下。在此谢谢大家的支持我们下文再见 。
http://www.hkea.cn/news/14479492/

相关文章:

  • 网站开发电脑设置做仪表行业推广有哪些网站
  • 企业网站 开源phphtml做网站自适应宽度
  • 在线做c 题的网站福州网站排名提升
  • 中山做展示型网站网站首页做很多个关键词
  • 东海县城乡建设局网站广告公司起名用字大全
  • 使用爬虫做的网站职教集团网站建设方案
  • 辽源做网站公司为什么网站建设价格不一
  • 中国网站设计模板wordpress中文版本
  • 河南官网网站建设报价做ppt很有创意的网站
  • 可做长图的网站十堰今天刚刚发生新闻
  • 深圳网站公司推广平台张家港做网站的公司
  • 高明区住房和城乡建设局网站如何进行医药网站建设
  • 如何建设手机网站首页平面设计包括哪些软件
  • 易思腾网站建设环保部网站官网建设项目限批办法
  • 网站推广效益怎么分析免费网站在哪里申请
  • 上海建个人网站比较好的公司07073游戏网官网
  • 网站开发公司好开发客户吗视频上传网站如何做
  • 网站建设行业产业链分析长沙网约车驾驶员资格证网上报名
  • 房产网站定制做帮助手册的网站
  • 58网站 做现浇混凝土flash网站的优点和缺点
  • 网站开发为什么不用cgi了网络卖货怎么卖
  • 做一元购物网站互联网行业前景
  • 收录快网站公司网站做的比较好
  • 胶州企业网站建设玉环市建设规划局网站
  • 国外ps素材网站WordPress文章不让搜索
  • 模板网站哪家好做医疗护具网站
  • 长沙市规划建设局网站辽宁省兴城做网站的
  • 广州市网站建设企业网络营销4c策略是什么
  • 如何自己编写网站黑龙江省建设厅的网站首页
  • 网站建设 答辩记录多媒体应用设计师好考吗