前端上传前预览文件image,text,json,video,audio

简介: 前天有个需求,上传前需要校验视频长度,然后让我出个 Demo。预览文件 demo其实预览功能实现上都差不多,所以今天我们都来实现一下咯。

选择文件


bVbGYYI.webp.jpg


一般来说上传常见的操作就三种,单击、拖拽、粘贴。下面我们分别来说一下。


input 选择文件


我们无法获取用户本地的内容,需要通过 <input> 标签,让用户自己选取。

<input type="file" name="input" id="input" @change="inputHandler">

但是 <input> 标签有个弊端:样式无法自定义(效果很奇怪)


我们这里通过 <label for="input"> 来和 <input id="input"> 标签关联(label 的 for 和 input 的 id 需要一样)起来,这样单击 <label> 和单击 <input> 的效果是一样的,而且 <label> 标签可以任意修改。


拖拽文件


之前有在文件上传中讲过。

<label for="input" class="upload-wrap"
    :class="{'upload-wrap--hover': dragover}"
    @drop.prevent="onDrop"
    @dragover.prevent="dragover = true"
    @dragleave.prevent="dragover = false">
@drop.prevent 是用来捕获结果的。
@dragover.prevent="dragover = true" 是用来捕获拖拽移入
@dragleave.prevent="dragover = false" 是用来捕获拖拽移出


粘贴文件


之前有在文件上传中讲过。

不过这个场景一般在富文本编辑器中比较常见(比如思否的编辑器,粘贴过来图片会上传),咱们这里不就讲了。


解析文件


音频&视频


通过 URL.createObjectURL 生成一个可访问的地址。

然后通过 audiovideo 解析这个资源,需要在 onloadedmetadata 回调里面再获取。


var file = el.files[0];
var video = document.createElement('video');
video.src = URL.createObjectURL(file);
video.onloadedmetadata = function(){
    console.log('长度', video.duration, 's')
}


图片


通过 URL.createObjectURL 生成一个可访问的地址。

然后通过 img 解析这个资源,需要在 onload 回调里面再获取。


var file = el.files[0];
var img = document.createElement('img');
img.src = URL.createObjectURL(file);
img.onload = function(){
    console.log('宽高', img.naturalWidth, img.naturalHeight)
}


文本


文本的话直接用 FileReader 就能读取。


var fileReader = new FileReader();
fileReader.readAsText(file)
fileReader.onload = () => {
    console.log(fileReader.result)
}


其他类型


  1. excel 有对应库 js-xlsx.js
  2. pdf 有对应库 pdf.js


有需求再说吧,目前的应该也满足业务要求了。


IE10 不支持拖拽,给所有事件都阻止默认事件即可(dragenter 我没加这个事件),就可以避免打开资源的问题。

相关文章
|
2月前
|
JSON 算法 vr&ar
目标检测笔记(五):查看通过COCOEvaluator生成的coco_instances_results.json文件的详细检测信息,包含AP、AR、MR和DR等
本文介绍了如何使用COCO评估器通过Detectron2库对目标检测模型进行性能评估,生成coco_instances_results.json文件,并利用pycocotools解析该文件以计算AP、AR、MR和DR等关键指标。
156 1
目标检测笔记(五):查看通过COCOEvaluator生成的coco_instances_results.json文件的详细检测信息,包含AP、AR、MR和DR等
|
3月前
|
前端开发
前端引入字体文件
文章介绍了如何在前端项目中引入字体文件,并展示了具体的HTML和CSS代码示例,包括如何使用`@font-face`规则来定义字体和在页面中应用自定义字体。
82 1
前端引入字体文件
|
1月前
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
43 4
|
3月前
|
前端开发 JavaScript API
前端JS读取文件内容并展示到页面上
前端JavaScript使用FileReader API读取文件内容,支持文本类型文件。在文件读取成功后,可以通过onload事件处理函数获取文件内容,然后展示到页面上。
118 2
前端JS读取文件内容并展示到页面上
|
2月前
|
JSON 数据格式 Python
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
这篇文章介绍了一个Python脚本,用于统计TXT或JSON文件中特定单词的出现次数。它包含两个函数,分别处理文本和JSON文件,并通过命令行参数接收文件路径、目标单词和文件格式。文章还提供了代码逻辑的解释和示例用法。
54 0
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
|
2月前
|
JSON 数据格式
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
141 2
|
3月前
|
前端开发
前端diff文件对比使用worker进行优化
如何使用Web Worker在React项目中优化文件对比差异功能的实现。
50 5
|
2月前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
198 0
|
2月前
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
214 0
|
2月前
|
JSON 数据格式 计算机视觉
Opencv实用笔记(一): 获取并绘制JSON标注文件目标区域(可单独保存目标小图)
本文介绍了如何使用OpenCV和Python根据JSON标注文件获取并绘制目标区域,同时可将裁剪的图像单独保存。通过示例代码,展示了如何读取图片路径、解析JSON标注、绘制标注框并保存裁剪图像的过程。此外,还提供了相关的博客链接,供读者进一步学习。
55 0