我的编程空间,编程开发者的网络收藏夹
学习永远不晚

利用vue怎么实现一个桌面向网页拖动文件的功能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

利用vue怎么实现一个桌面向网页拖动文件的功能

本文章向大家介绍利用vue怎么实现一个桌面向网页拖动文件的功能的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

vue是什么软件

Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

不显示图片/播放视频音频代码如下

<template> <div>  <div v-on:dragover="tts" v-on:drop="ttrs" >   {{dt}}  </div>  <div v-for="(item,index) in fileList" :key="index" >   <p >{{item.name}}</p>   <h6 >{{item.type}}</h6>   <h7 >{{item.size | sizeType}}</h7>   <button  @click="del(index)">删除</button>  </div> </div></template><script> export default {  name: "trs",  data(){   return{    dt:"",    fileList:[]   }  },  filters:{   sizeType(val){    let kbs = val/1024;    let mbs = 0;    let gbs = 0;    if(kbs>=1024){     mbs = kbs/1024;    }    if(mbs>=1024){     gbs=mbs/1024     return gbs.toFixed(2)+"GB";    }else if (mbs>=1){     return mbs.toFixed(2)+"MB"    }else {     return kbs.toFixed(2)+"KB"    }   }  },  mounted() {   let vm = this;   window.addEventListener("dragdrop", this.testfunc, false);   document.addEventListener("dragover",function () {    console.log(111)    vm.dt = "拖动到此处上传文件"    console.log(vm.dt)   })  },  methods:{   testfunc(event) {    alert("dragdrop!");    event.stopPropagation();    event.preventDefault();   },   del(index){    this.fileList.splice(index,1)    if(this.fileList.length==0){     this.dt = ""    }   },   tts(e){    console.log(e)    this.dt = "拖动到此处上传文件"   },   ttrs(e){    console.log(e)    console.log(e.dataTransfer.files)    let datas = e.dataTransfer.files;    datas.forEach(item=>{     this.fileList.push(item)    })    e.stopPropagation();    e.preventDefault();    this.dt = "上传完成,可继续上传"   }  } }</script><style scoped></style>

如果想要显示图片/播放视频/播放音频

这里我默认显示/播放最后一个上传文件 根据需求修改即可

<template> <div> <div  v-on:dragover="tts"  v-on:drop="ttrs"   >  {{ dt }} </div> <div  v-for="(item, index) in fileList"  :key="index"   >  <p    >  {{ item.name }}  </p>  <h6 >  {{ item.type }}  </h6>  <h7 >  {{ item.size | sizeType }}  </h7>  <button  @click="del(index)">删除</button> </div> <div >  <img v-if="isImage" :class="lazy" data-src="class="lazy" data-srcs"  />  <video v-if="isVideo" controls :class="lazy" data-src="class="lazy" data-srcs" ></video>  <audio v-if="isAudio" controls :class="lazy" data-src="class="lazy" data-srcs" ></audio> </div> </div></template><script>export default { name: "trs", data() { return {  dt: "",  fileList: [],  class="lazy" data-srcs:"",  isImage:false,  isAudio:false,  isVideo:false }; }, filters: { sizeType(val) {  let kbs = val / 1024;  let mbs = 0;  let gbs = 0;  if (kbs >= 1024) {  mbs = kbs / 1024;  }  if (mbs >= 1024) {  gbs = mbs / 1024;  return gbs.toFixed(2) + "GB";  } else if (mbs >= 1) {  return mbs.toFixed(2) + "MB";  } else {  return kbs.toFixed(2) + "KB";  } } }, mounted() { let vm = this; window.addEventListener("dragdrop", this.testfunc, false); document.addEventListener("dragover", function() {  console.log(111);  vm.dt = "拖动到此处上传文件";  console.log(vm.dt); }); }, methods: {  readFile(file){   let vm = this;   let reader = new FileReader();   reader.readAsDataURL(file)   reader.onload = function () {    let type = file.type.substr(0,5);    if(type=="image"){     vm.isImage = true;     vm.isAudio =false;     vm.isVideo = false;    }else if(type=="audio"){     vm.isImage = false;     vm.isAudio =true;     vm.isVideo = false;    }else if(type=="video"){     vm.isImage = false;     vm.isAudio = false;     vm.isVideo = true;    }else {     alert("不是图片/视频/音频")    }    vm.class="lazy" data-srcs = reader.result;    // this.$nextTick(()=>{    //    // })   }  }, testfunc(event) {  alert("dragdrop!");  event.stopPropagation();  event.preventDefault(); }, del(index) {  this.fileList.splice(index, 1);  if (this.fileList.length === 0) {  this.dt = "";  } }, tts(e) {  console.log(e);  this.dt = "拖动到此处上传文件"; }, ttrs(e) {  console.log(e);  console.log(e.dataTransfer.files);  let datas = e.dataTransfer.files;  datas.forEach(item => {  this.fileList.push(item);  });  this.readFile(this.fileList[this.fileList.length-1])  e.stopPropagation();  e.preventDefault();  this.dt = "上传完成,可继续上传"; } }};</script><style scoped></style>

以上就是小编为大家带来的利用vue怎么实现一个桌面向网页拖动文件的功能的全部内容了,希望大家多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

利用vue怎么实现一个桌面向网页拖动文件的功能

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

利用vue怎么实现一个桌面向网页拖动文件的功能

本文章向大家介绍利用vue怎么实现一个桌面向网页拖动文件的功能的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。vue是什么软件Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区
2023-06-06

怎么在Java中利用dropzone.js实现一个文件拖拽上传功能

本篇文章为大家展示了怎么在Java中利用dropzone.js实现一个文件拖拽上传功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。jsp页面:1. 首先必须引入dropzone的js和css文件<
2023-05-31

利用java怎么实现一个网页爬虫功能

利用java怎么实现一个网页爬虫功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。爬虫实现原理网络爬虫基本技术处理网络爬虫是数据采集的一种方法,实际项目开发中,通过爬虫做数
2023-05-31

实例讲解怎么用vue实现一个侧边栏拖动功能

Vue 是一款流行的 JavaScript 框架,可以让开发者快速构建现代、响应式的 Web 应用程序。其中很有趣的一个功能是侧边栏拖动,这是一项非常流行和实用的功能,本文将介绍如何使用 Vue 实现侧边栏拖动。首先,需要安装 Vue.js,可以使用 npm 或 yarn 安装,并在项目中引入 Vue.js:```html<script src="https://cdn.jsd
2023-05-14

使用ajax怎么实现一个拖拽上传文件功能

本篇文章给大家分享的是有关使用ajax怎么实现一个拖拽上传文件功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。<
2023-06-08

利用Servlet怎么实现一个文件下载功能

本篇文章给大家分享的是有关利用Servlet怎么实现一个文件下载功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Web容器为Servlet生成并且传递的HttpServlet
2023-05-31

利用Struts怎么实现一个文件上传功能

这期内容当中小编将会给大家带来有关利用Struts怎么实现一个文件上传功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.在jsp文件中进行定义
2023-05-31

利用servlet怎么实现一个文件上传功能

本篇文章为大家展示了利用servlet怎么实现一个文件上传功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.servlet上传文件  servlet上传文件就是将客户端的文件上传到服务器端。  
2023-05-31

利用hadoop怎么实现一个文件上传功能

本篇文章给大家分享的是有关利用hadoop怎么实现一个文件上传功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。hdfs上的文件是手动执行命令从本地linux上传至hdfs的。
2023-05-31

怎么在Centos中利用文件实现一个swap功能

怎么在Centos中利用文件实现一个swap功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。创建swap文件mkdir/var/swap#创建一个文件夹用于存放交换分区文件,
2023-06-10

利用Spring MVC怎么实现一个文件上传功能

本篇文章给大家分享的是有关利用Spring MVC怎么实现一个文件上传功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、使用Spring MVC 上传文件必须配置文件解析器
2023-05-31

怎么利用vue组件实现图片的拖拽和缩放功能

这篇文章将为大家详细讲解有关怎么利用vue组件实现图片的拖拽和缩放功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言vue实现一个组件其实很简单但是要写出一个好的可复用的组件那就需要多学
2023-06-26

怎么在Java中利用JScrollPane实现一个面板滚动功能

这篇文章将为大家详细讲解有关怎么在Java中利用JScrollPane实现一个面板滚动功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 JScrollPane 面板是带滚动条
2023-05-31

Android应用中怎么实现一个滑动切换页面功能

Android应用中怎么实现一个滑动切换页面功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 TabLayou 主要实现的是标题头的 滑动 这个 控件 类似于 ScrollV
2023-05-31

利用servlet怎么实现一个文件上传下载功能

利用servlet怎么实现一个文件上传下载功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、准备工作:  1.1 文件上传插件:uploadify;  1.2 文件上传所需
2023-05-31

怎么在Android应用中利用RecyclerView实现一个分页滚动功能

怎么在Android应用中利用RecyclerView实现一个分页滚动功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、需求分析最近公司项目要实现一个需求要满足以下功能
2023-05-31

怎么在Android中利用DownloadManager实现一个文件下载功能

本篇文章为大家展示了怎么在Android中利用DownloadManager实现一个文件下载功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Android中DownloadManager实现文件下
2023-05-31

怎么在HTML5中Blob利用实现一个文件下载功能

怎么在HTML5中Blob利用实现一个文件下载功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。$("#exportAll").on("click",funct
2023-06-09

利用JavaScript怎么实现一个拖拽鼠标调整div大小的功能

本篇文章为大家展示了利用JavaScript怎么实现一个拖拽鼠标调整div大小的功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向
2023-06-07

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录