Uppy - 免费开源、功能强大的新一代文件上传组件,支持集成 Vue 项目

boyanx6个月前技术教程31

Uppy 这个优质的前端组件,可以解决几乎所有的文件上传问题,最近发布了 TS 重写的 4.0 新版本,实用性更强了。

Uppy 简介

Uppy 是一个 UI 外观时尚、模块化的 JavaScript 文件上传组件,这个组件可以与任何 web 技术栈集成,不仅轻量速度快,拥有断点续传、国际化,以及预览、编辑和多文件上传的功能,提供的 API 很容易上手理解,可以帮开发者解决前端开发遇到的各种麻烦的文件上传问题。

uppy 官网

Uppy.js ?

网上不少文章称为 Uppy.js,实际上 .js 后缀一般是作为 JavaScript 工具库的名称,而官方命名的 Uppy,也说明了这是一个拥有 UI 界面的组件,所以我这篇文章还是沿用 Uppy 这个名称吧。

对了,为什么叫 Uppy,其实官方是这样形容这个组件的:

Cute as a puppy.

— 像小狗一样可爱

我个人也非常喜欢这个简单有创意的名字。

Uppy 的技术特性

  • 漂亮新潮的外观,以及基于新一代浏览器打造的优秀体验;
  • 模块化的架构,所有功能都可以通过插件来实现;
  • 支持多种上传方式:包括拖放、选择文件、摄像头捕捉等,能够满足不同场景下的需求;
  • 内置事件管理系统,可以方便地进行上传状态监听和错误处理;
  • 支持多种语言,当然也支持中文。

开发上手体验

4种上传界面

Uppy 虽然只是一个组件,但它提供了四种类型上传界面:

  1. Dashboard :具有预览、进度条、元数据编辑器和所有很酷的东西的通用 UI,适合大而全的文件上传场景;
  2. Progress Bar 进度条:只有一个小巧的进度条,适合用来上传简单小巧的文件;
  3. Status Bar 状态栏:有详细的进度、暂停/恢复/取消按钮、百分比、速度、上传/总大小等信息,适合多文件上传的场景;
  4. Informer 只在上传成功或失败时跳出状态表情的通知,更轻量的展示方式。

我们只需要根据自己项目的需求来选择展示的方式即可。Dashboard 方式除了本地选择文件,还支持远程URL、Google Drive、Dropbox、Box、Instagram 等国外通用方式获取文件。

图片上传列表

上传前编辑

安装使用

Uppy 几乎支持所有的技术栈,官方提供了 Vue / React / Svelte / Angular 项目的集成方式,我们可以根据实际情况去查阅。

Vue 集成

这里为了演示方便,就直接通过引入 js 文件的方式来集成。

<html>
... 
<!-- 1. 引入组件的 CSS 样式 -->
<link href="uppy.min.css" rel="stylesheet">

<!-- 2. 引入js -->
<script src="uppy.min.js"></script>

<!-- 3. 最简单的初始化 -->
<div class="DragDrop"></div>
<script>
  const uppy = Uppy.Core();
  uppy.use(Uppy.DragDrop, { target: '.DragDrop' });
  // endpoint 是文件上传到后端的 api 地址
  uppy.use(Uppy.Tus, { endpoint: 'https//xxx.com/upload/' });
</script>
<html>

这样一个简单的拖拽上传文件的组件就做好了,功能强大,但用起来是真的简单。Uppy 的官方做得也很漂亮,更多的用法可以去官网看看。

用法展示

免费开源说明

Uppy 是一个免费开源的 web 文件上传组件,基于 MIT 开源协议,我们可以自由地下载来使用,也可以用在商业项目上

Uppy 这个项目由 Transloadit 团队开发并且维护,这是一个小的技术团队,除了开源项目,他们也提供了商业服务项目,他们希望通过开源项目帮助更多技术人,同时宣传他们的商业项目。

↓↓点击查看本次分享的网站。

Uppy - 免费开源、功能强大的新一代 web 文件上传组件,支持集成到 Vue 项目|那些免费的砖

标签: js 上传文件

相关文章

JBoltAI赋能Java技术团队,轻松构筑AI应用开发能力

在当今数字化时代,人工智能(AI)技术正以前所未有的速度改变着各个行业。对于Java技术团队而言,掌握AI应用开发能力已成为提升竞争力的关键。JBoltAI作为一款强大的AI开发工具,正致力于为Jav...

JavaScript 如何压缩目录并上传?

本文转载自微信公众号「全栈修仙之路」,作者阿宝哥。转载本文请联系全栈修仙之路公众号。在日常工作中,文件上传是一个很常见的功能。在上传文件时,我们可以选择上传单个文件,也可以通过设置 multiple...

Vue 前端开发——导入Excel/Csv

项目开发中遇到导入表格常见的就是excel和csv 格式,一般情况下我们会前端首先得到这个表格里面的数据,然后再把数据发送给后端,也有的是直接上传文件传给后台后台自己处理,这样就不好控制上传前预览和处...

java项目中接入大模型,简历必备

spring-ai我们使用spring-ai 接入大模型spring-ai支持的组件有chatclient负责和大模型进行交互,发送模型参数,解析模型参数的重要框架chatclient 如何和模型进行...

十分钟教会你用 docker 创建 jmeter 容器,实现性能测试

我们都知道,jmeter可以做接口测试,也可以用于性能测试,现在企业中性能测试也大多使用jmeter。docker是最近这些年流行起来的容器部署工具,可以创建一个容器,然后把项目放到容器中,就可以构建...

2小时快速搭建一个高可用的IM系统

“笔者 2019 年参加了一次 Gopher 大会,有幸听探探的架构师分享了他们 2019 年微服务化的过程。图片来自 Pexels本文快速搭建的 IM 系统也是使用 Go 语言来快速实现的,这里先和...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。