使用WebUploader实现上传文件功能(一)

使用WebUploader实现上传文件功能(一)是一篇介绍如何在网站中使用WebUploader插件来实现文件上传功能的文章。

以下是该文章的详细攻略:

1. 确认环境

在使用WebUploader之前,需要确认网站中是否已经引入了jQuery和WebUploader的JavaScript文件。如果没有引入,需要先在需要使用上传功能的页面中引入这些文件。

2. 创建容器

在页面中创建一个容器元素,用于显示上传文件列表和上传进度等信息。例如:

<div id="uploader">
    <div class="queueList">
        <div id="dndArea" class="placeholder">
            <div class="filePicker"></div>
            <p>或将文件拖到这里,单次最多可选300个文件</p>
        </div>
    </div>
    <div class="statusBar" style="display:none;">
        <div class="progress">
            <span class="text">0%</span>
            <span class="percentage"></span>
        </div><div class="info"></div>
        <div class="btns">
            <div class="filePicker2"></div><div class="uploadBtn">开始上传</div>
        </div>
    </div>
</div>

3. 创建WebUploader实例

在页面加载完成后,创建WebUploader实例,并初始化参数。例如:

<script type="text/javascript">
    var uploader = WebUploader.create({
        // 选完文件后,是否自动上传。
        auto: true,

        // swf文件路径
        swf: 'http://cdn.staticfile.org/webuploader/0.1.5/Uploader.swf',

        // 文件接收服务端。
        server: '/fileupload.php',

        // 选择文件的按钮容器,不指定则不创建按钮。
        pick: '#filePicker',

        // 只允许选择文件,可选。
        accept: {
            title: 'Files',
            extensions: 'pdf,doc,docx,xls,xlsx,ppt,pptx',
            mimeTypes: 'application/pdf,application/msword,application/vnd.ms-excel,application/vnd.ms-powerpoint'
        }
    });
</script>

其中,参数的含义如下:

  • auto:选完文件后,是否自动上传,默认为false。
  • swf:Uploader.swf文件所在的路径。
  • server:文件上传的服务器端地址。
  • pick:选择文件的按钮容器,可以是一个元素,也可以是一个CSS选择器。
  • accept:对上传文件的类型和大小进行限制。

4. 定义上传事件

定义上传开始、上传过程和上传结束等事件,以便在上传过程中更新上传进度和文件列表等信息。例如:

<script type="text/javascript">
    // 当有文件被添加进队列的时候
    uploader.on( 'fileQueued', function( file ) {
        var $li = $(
            '<div id="' + file.id + '" class="file-item thumbnail">' +
                '<img>' +
                '<div class="info">' + file.name + '</div>' +
            '</div>'
            ),
            $img = $li.find('img');

        // $list为容器jQuery实例
        $('#fileList').append( $li );

        // 创建缩略图
        uploader.makeThumb( file, function( error, src ) {
            if ( error ) {
                $img.replaceWith('<span>不能预览</span>');
                return;
            }

            $img.attr( 'src', src );
        }, 100, 100 );
    });

    // 文件上传过程中创建进度条实时显示。
    uploader.on( 'uploadProgress', function( file, percentage ) {
        var $li = $( '#'+file.id ),
            $percent = $li.find('.progress span');

        // 避免重复创建
        if ( !$percent.length ) {
            $percent = $('<p class="progress"><span></span></p>')
                    .appendTo( $li )
                    .find('span');
        }

        $percent.css( 'width', percentage * 100 + '%' );
    });

    // 文件上传成功,给item添加成功class,并移除上传按钮
    uploader.on( 'uploadSuccess', function( file ) {
        $( '#'+file.id ).addClass('upload-state-done');
    });

    // 文件上传失败,显示上传出错
    uploader.on( 'uploadError', function( file ) {
        $( '#'+file.id ).find('.text').text('上传出错');
    });
</script>

其中,上传事件的含义如下:

  • fileQueued:当有文件被添加进队列的时候触发。
  • uploadProgress:文件上传过程中创建进度条实时显示。
  • uploadSuccess:文件上传成功,给相应的文件添加上传成功的样式。
  • uploadError:文件上传失败,显示上传出错信息。

5. 示例说明

示例1:上传文件到服务器端

以下示例将文件上传到服务器端,以PHP为例。

<?php
    $targetDir = '/uploads/';
    $tempFile   = $_FILES['file']['tmp_name'];
    $targetFile = $targetDir . basename($_FILES['file']['name']);
    move_uploaded_file($tempFile, $targetFile);
?>

示例2:使用SDK将文件上传到阿里云OSS

以下示例使用阿里云OSS SDK将文件上传到阿里云OSS,并返回文件的访问URL。

<script type="text/javascript">
    var uploader = WebUploader.create({
        // ...

        // 文件接收服务端。
        server: '/fileupload.php',

        // ...

        // 文件上传成功,获取文件访问URL
        uploader.on( 'uploadSuccess', function( file, response ) {
            var filename = response.filename;

            OSS.urllib.request(filename, {
                    method: 'GET'
                }, function (err, response) {
                    if (err) {
                        console.log(err);
                        return;
                    }
                    console.log(response);
            });
        });

        // ...

    });
</script>

其中,filename是在上传成功后返回的OSS文件路径。通过OSS.urllib.request方法,获取该文件的访问URL。实际使用中,需要安装和配置好阿里云OSS SDK。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:使用WebUploader实现上传文件功能(一) - Python技术站

(0)
上一篇 2023年6月15日
下一篇 2023年6月15日

相关文章

  • java 格式化输出数字的方法

    当我们用Java编写程序时,经常需要将数字以指定格式输出。Java中提供了一些方法来格式化输出数字,这些方法包括使用String.format()和System.out.printf()等。 使用String.format()方法 使用String.format()方法可以使代码更简洁,通常使用以下的语法格式: String formattedString …

    Java 2023年5月26日
    00
  • Jersey实现Restful服务(实例讲解)

    Jersey 是一个开源、功能强大的框架,用于为 Java 应用程序提供面向资源的 RESTful Web Services。它提供了一种简单的必要 API 和工具,用于快速开发并构建可伸缩、互操作的 RESTful Web Services。 以下是 Jersey 实现 RESTful 服务的完整攻略: 一、准备工作 安装 JDK 和 Eclipse 下载…

    Java 2023年5月19日
    00
  • Java 数组交集的实现代码

    下面是Java数组交集的实现代码完整攻略。 实现思路 交集是指两个集合中都存在的元素,可以用两种方法来实现数组交集。 嵌套循环:在第一个数组中循环遍历每个元素,在第二个数组中再循环遍历每个元素,如果两个元素相等,则为交集元素之一。 HashSet数据结构:使用HashSet将第一个数组中的元素都添加进去,然后遍历第二个数组,在HashSet中查找是否存在相同…

    Java 2023年5月26日
    00
  • java编程实现杨辉三角两种输出结果实例代码

    下面是“java编程实现杨辉三角两种输出结果实例代码”的完整攻略。 什么是杨辉三角? 杨辉三角是二项式系数在三角形中的一种几何排列,中文名称又称“杨辉三角形”,它形状如下图所示: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 … … … 如何用java编程实现杨辉三角? 第一种实现方式 下面是用java编…

    Java 2023年5月23日
    00
  • 详解java数组进行翻转的方法有哪些

    详解Java数组进行翻转的方法有哪些 Java中提供了多种翻转数组的方法,可以通过修改数组元素的顺序或者创建新数组来实现。本文将为大家介绍四种常用的翻转数组的方法。 1. 利用for循环实现 public static int[] reverseArray(int[] array) { int length = array.length; int[] res…

    Java 2023年5月26日
    00
  • Java的Struts框架报错“ActionForwardNotFoundException”的原因与解决办法

    当使用Java的Struts框架时,可能会遇到“ActionForwardNotFoundException”错误。这个错误通常由以下原因之一起: 配置错误:如果ActionForward配置不正确可能会出现。在这种情况下,需要检查ActionForward配置以解决此问题。 URL路径问题:如果URL路径不正确,则可能会出现此。在种情况下,需要检查URL路…

    Java 2023年5月5日
    00
  • 浅聊JVM–基础版

    浅聊JVM–基础版 一、来源 jvm共有三种 Sun公司: HotSpot使用最多 BEA:JRockit IBM:J9VM ​ 今天我们主要了解的是Sun公司的HotSpot(关于HotSpot的爱恨情仇这里就不做过多解释了。)我们以前测试jdk是否安装成功,java的环境变量是否配置成功会使用java -version命令来检查。有一个细节大家可以看一…

    Java 2023年5月7日
    00
  • 如何在Java中实现一个散列表

    散列表(Hash Table)是一种以键值对结构存储数据的数据结构,它可以高效地实现插入、删除和查找操作。在Java中,我们可以使用HashMap来实现一个散列表。 下面是实现一个散列表的步骤: 定义一个HashMap对象 在Java中,我们可以使用HashMap来实现散列表。因此,首先要定义一个HashMap对象。我们可以使用以下语法: HashMap&l…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部