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

boyanx2周前技术教程4

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 上传文件

相关文章

JavaScript 如何压缩目录并上传?

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

413 Request Entity Too Large Sorry for the inconvenience.解决方案-

413 Request Entity Too Large Sorry for the inconvenience.解决方案-Powered by Tengine tengine采用了tengine-优...

老婆上班总让我找文件,手把手教会她用群晖的 Drive 自己找

本内容来源于@什么值得买APP,观点仅代表作者本人 |作者:晓飞影我喜欢用 NAS 下电影,整理电影墙,安装 docker 跑很多有趣的服务,映射端口公网访问,安装虚拟机远程使用 win系统等等。但是...

网络安全之对文件上传的思考

在web渗透中,最简单直接的方式就是文件上传。但是不做任何检测,直接getshell的现在已经很少了.我在平时的授权测试中,遇到的大多数都是对上传的文件内容,格式等检测的比较多的按前端到后端绕过顺序分...

采用Oracle OSB总线进行服务注册和接入

做大型企业内部业务系统集成的应该都知道,Oracle SOA套件当前是应用广泛的一个商业集成产品套件,其中包括了OSB服务总线, BPEL业务流程引擎,BPM业务流程管理,ODI大数据服务集成,MFT...

全新“一碰互传”即将登陆一加13手机

10 月 30 日消息,一加手机官微今天上午宣布,一加 13 将会搭载全新“一碰互传”功能,该机用户可与 iPhone 用户通过“碰一碰”手机的方式互相传输照片、视频、文档。本月早些时候,OPPO 宣...

发表评论    

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