【精心推荐】几款极好的 JavaScript 文件上传插件
文件上传功能作为网页重要的组成部分,几乎无处不在,从简单的单个文件上传到复杂的批量上传、拖放上传,需要开发者花费大量的时间和精力去处理,以期实现好用的上传功能。这篇文章向大家推荐几款很棒的 JavaScript 文件上传功能增强插件。
这是最受欢迎的 jQuery 文件上传组件,支持批量上传,拖放上传,显示上传进度条以及校验功能。
支持预览图片、音频和视频,支持跨域上传和客户端图片缩放,支持的服务端平台有:PHP, Python, Ruby on Rails, Java, Node.js, Go 等等。
使用示例:
- $(function () {
- 'use strict';
- // Change this to the location of your server-side upload handler:
- var url = window.location.hostname === 'blueimp.github.io' ?
- '//jquery-file-upload.appspot.com/' : 'server/php/';
- $('#fileupload').fileupload({
- url: url,
- dataType: 'json',
- done: function (e, data) {
- $.each(data.result.files, function (index, file) {
- $('<p/>').text(file.name).appendTo('#files');
- });
- },
- progressall: function (e, data) {
- var progress = parseInt(data.loaded / data.total * 100, 10);
- $('#progress .progress-bar').css(
- 'width',
- progress + '%'
- );
- }
- }).prop('disabled', !$.support.fileInput)
- .parent().addClass($.support.fileInput ? undefined : 'disabled');
- });
DropzoneJS 是一个用于现代浏览器的开源的拖放上传插件,最大的特色是即时图片预览功能。
使用方法非常简单,只需添加 class 即可:
- <form id="my-awesome-dropzone" action="/target" class="dropzone"></form>
或者手动实例化:
- new Dropzone("div#my-dropzone", { /* options */ });
可以添加更多参数:
- Dropzone.options.myAwesomeDropzone = { maxFilesize: 1 };
发可以自定义事件:
- Dropzone.options.myDropzone({
- init: function() {
- this.on("error", function(file, message) { alert(message); });
- }
- });
- // or if you need to access a Dropzone somewhere else:
- var myDropzone = Dropzone.forElement("div#my-dropzone");
- myDropzone.on("error", function(file, message) { alert(message); });
Uploadify 有两个版本,HTML5 方法上传版本和传统的 Flash 上传。支持高度自定义,可以完美的继承到你的网站中。
Flash 版本兼容性好,使用示例:
- $(function() {
- $("#file_upload_1").uploadify({
- height : 30,
- swf : '/uploadify/uploadify.swf',
- uploader : '/uploadify/uploadify.php',
- width : 120
- });
- });
这个 JavaScript 插件可以帮助你在网站中集成体验极好的文件上传功能。可以结合 jQuery 或者 Bootstrap 使用。
主要特色:
- 批量上传
- 显示进度条
- 拖放上传
- 自动或者手动上传,可取消
- 自定义错误提示信息
- 自动或者手动重试
- 内置的校验规则
- 可编辑文件名称
使用示例:
(1)手动触发上传
- <div id="manual-fine-uploader"></div>
- <div id="triggerUpload" class="btn btn-primary" style="margin-top: 10px;">
- <i class="icon-upload icon-white"></i> Upload now
- </div>
- <script src="http://code.jquery.com/jquery-latest.js"></script>
- <script src="jquery.fineuploader-{VERSION}.js"></script>
- <script>
- $(document).ready(function() {
- var manualuploader = $('#manual-fine-uploader').fineUploader({
- request: {
- endpoint: 'server/handleUploads'
- },
- autoUpload: false,
- text: {
- uploadButton: '<i class="icon-plus icon-white"></i> Select Files'
- }
- });
- $('#triggerUpload').click(function() {
- manualuploader.fineUploader('uploadStoredFiles');
- });
- });
- </script>
(2)编辑文件名称
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>Fine Uploader - jQuery Wrapper Minimal Demo</title>
- <link href="fineuploader-{VERSION}.css" rel="stylesheet">
- </head>
- <body>
- <div id="jquery-wrapped-fine-uploader"></div>
- <div id="triggerUpload" class="btn btn-primary" style="margin-top: 10px;">
- <i class="icon-upload icon-white"></i> Upload now
- </div>
- <script src="http://code.jquery.com/jquery-latest.js"></script>
- <script src="jquery.fineuploader-{VERSION}.js"></script>
- <script>
- $(document).ready(function () {
- $('#myFineUploader').fineUploader({
- request: {
- endpoint: 'server/handleUploads'
- },
- editFilename: {
- enabled: true
- },
- autoUpload: false
- });
- $('#triggerUpload').click(function() {
- $('#myFineuploader').fineUploader('uploadStoredFiles');
- });
- </script>
- </body>
- </html>
(3)自定义选项
- <div id="restricted-fine-uploader"></div>
- <script src="http://code.jquery.com/jquery-latest.js"></script>
- <script src="jquery.fineuploader-{VERSION}.js"></script>
- <script>
- $(document).ready(function() {
- $('#restricted-fine-uploader').fineUploader({
- request: {
- endpoint: 'server/success.html'
- },
- multiple: false,
- validation: {
- allowedExtensions: ['jpeg', 'jpg', 'txt'],
- sizeLimit: 51200 // 50 kB = 50 * 1024 bytes
- },
- text: {
- uploadButton: 'Click or Drop'
- },
- showMessage: function(message) {
- // Using Bootstrap's classes
- $('#restricted-fine-uploader').append('<div class="alert alert-error">' + message + '</div>');
- }
- });
- });
- </script>
(4)显示图片缩略图
- <div id="thumbnail-fine-uploader"></div>
- <script src="http://code.jquery.com/jquery-latest.js"></script>
- <script src="jquery.fineuploader-{VERSION}.js"></script>
- <script>
- $(document).ready(function() {
- $('#thumbnail-fine-uploader').fineUploader({
- request: {
- endpoint: 'server/success.html'
- },
- validation: {
- allowedExtensions: ['jpeg', 'jpg', 'gif', 'png']
- },
- text: {
- uploadButton: 'Click or Drop'
- }
- }).on('complete', function(event, id, fileName, responseJSON) {
- if (responseJSON.success) {
- $(this).append('<img src="img/success.jpg" alt="' + fileName + '">');
- }
- });
- });
- </script>
(5)限制文件上传数
- <div id="filelimit-fine-uploader"></div>
- <script src="http://code.jquery.com/jquery-latest.js"></script>
- <script src="jquery.fineuploader-{VERSION}.js"></script>
- <script>
- $(document).ready(function() {
- $('#filelimit-fine-uploader').fineUploader({
- request: {
- endpoint: 'server/success.html'
- },
- validation: {
- itemLimit: 3
- }
- });
- });
- </script>
本文链接:精心推荐几款很棒的 JavaScript 文件上传插件
编译来源:梦想天空 ◆ 关注前端开发技术 ◆ 分享网页设计资源
【精心推荐】几款极好的 JavaScript 文件上传插件的更多相关文章
- 几款极好的 JavaScript 文件上传插件
文件上传功能作为网页重要的组成部分,几乎无处不在,从简单的单个文件上传到复杂的批量上传.拖放上传,需要开发者花费大量的时间和精力去处理,以期实现好用的上传功能.这篇文章向大家推荐几款很棒的 JavaS ...
- Javascript文件上传插件
jQuery File Uploader 这是最受欢迎的 jQuery 文件上传组件,支持批量上传,拖放上传,显示上传进度条以及校验功能. 支持预览图片.音频和视频,支持跨域上传和客户端图片缩放,支持 ...
- 7 款基于 JavaScript/AJAX 的文件上传插件
本文整理了7款基于JavaScript和AJAX的文件上传插件,这些插件基本上都能实现以下功能: 多文件上传 拖拽操作 实时上传进度 自定义上传限制 希望能为你的开发工作带来帮助. 1. jQuer ...
- 20款最好的jQuery文件上传插件
当它是关于开发网络应用程序和网页的时候,文件上传功能的重要性是不容忽视的.一个文件上传功能可以让你上传所有类型的文件在网站上,包括视频,图像,文件和更多.创建一个文件上传功能,对你的网站是不是很难,有 ...
- 7款js文件上传插件
1. jQuery File Upload 具有多文件上传.拖拽.进度条和图像预览功能的文件上传插件,支持跨域.分块.暂停恢复和客户端图像缩放.可与任何服务端平台(如PHP.Python.Ruby ...
- 体验三大JavaScript文件上传库(Uppy.js/Filepond/Dropzone)
最近发现了一个高颜值的前端上传组件Uppy.js,立即上手体验了一波,感觉还不错.然后又看到同类型的Filepond以及Dropzone.js,对比体验了一下,感觉都很优秀,但是在体验过程中,都遇到了 ...
- JavaScript 文件上传类型判断
文件上传时用到一个功能,使用html元素的input标签实现, <input id="imageFile" name="imageFile1" accep ...
- HTML5 JavaScript 文件上传
function fileUpload(targetUrl) { // 隐藏表单名称 var inputName = '_fileselect'; // 文件尺寸 this.fileSize = 0; ...
- 一款基于uploadify扩展的多文件上传插件,完全适用于Html5
http://www.uploadify.com/documentation/ 官网里面有两个插件,一个是要使用flash插件才能文件上传的插件,另外一个是不需要使用要flash插件的文件上传插件完 ...
随机推荐
- 如何用sublime 编写sass
使用了Sublime Text也有一段时日了,然后在现在而言,小觉的coding工具已经非其莫属了,接着小觉因为近期忙着项目的原因,同时还要抽空编辑博客的原因,就暂时把它放在一旁了,现在偶然想起也就说 ...
- javascript学习目录
类型系统 [1]基本数据类型 [2]引用类型中的对象Object [3]引用类型中的数组Array [4]引用类型中的时间Date [5]函数Function [6]正则表达式RegExp [7]包装 ...
- 2014牡丹江网络赛ZOJPretty Poem(暴力枚举)
/* 将给定的一个字符串分解成ABABA 或者 ABABCAB的形式! 思路:暴力枚举A, B, C串! */ 1 #include<iostream> #include<cstri ...
- java中自动装箱的问题
package wrapper; public class WrapperDemo { public static void main(String[] args) { Integer a=new I ...
- C++中typename关键字的用法
我在我的 薛途的博客 上发表了新的文章,欢迎各位批评指正. C++中typename关键字的用法
- CSS3的学习--实现瀑布流
基于CSS3实现瀑布流,使用CSS3的CSS 多栏(Multi-column). 可以到github上下载源码 : https://github.com/CraryPrimitiveMan/water ...
- 数据可视化(8)--D3数据的更新及动画
最近项目组加班比较严重,D3的博客就一拖再拖,今天终于不用加班了,赶紧抽点时间写完~~ 今天就将D3数据的更新及动画写一写~~ 接着之前的博客写~~ 之前写了一个散点图的例子,下面可以自己写一个柱状图 ...
- Project简介
Microsoft Project (Project)是一个国际上享有盛誉的通用的项目管理工具软件,凝集了许多成熟的项目管理现代理论和方法,可以帮助项目管理者实现时间.资源.成本的计划.控制,协助项目 ...
- 修改cdh5集群中主机节点IP或hostName
前言 在使用cdh集群过程中,难免会因为某些不可抗拒的原因导致节点IP或hostName变动,而cm的监控界面无法完成这些事情,但是cm将集群中所有的主机的信息都存在postgresql数据库的hos ...
- JQuery02
一:JQuery知识点 *:JQuery的dom操作 *:动态创建dom节点 比如动态创建表格等,在js里面进行完成. *删除节点 这里面的删除就是将其放在了一个地方,并不是真的删除,之后可以使用. ...