Blueimp jQuery文件上传音频/视频预览

时间:2014-01-10 14:50:25

标签: jquery-plugins jquery-file-upload

经过一些谷歌搜索后,我找不到使用音频和放大器的例子。 jQuery文件上传插件的视频预览扩展。

http://blueimp.github.io/jQuery-File-Upload/

有没有人使用过能够提供最小例子的人?

1 个答案:

答案 0 :(得分:5)

当您使用插件上传视频时,您只需添加jquery.fileupload-video文件。这就是我使用它的方式

$(function () {
    'use strict';
    var url = YourURL+"public/server/php/";

    $('#fileupload').fileupload({
        url: url,
        method: 'POST',
        dataType: 'json',
        autoUpload: true,
        acceptFileTypes: /(\.|\/)(mp4)$/i,
        maxFileSize: 40000000, // 40 MB
        disableImageResize: /Android(?!.*Chrome)|Opera/
            .test(window.navigator.userAgent),
        previewMaxWidth: 300,
        previewMaxHeight: 200,
        previewCrop: true,
    }).on('fileuploadadd', function (e, data) {
        data.context = $('<div class="col-md-3 videopreview" />').appendTo('#files');
        $.each(data.files, function (index, file) {
            var node = $('<p/>');
            if (!index) {
                node
                    .append('<br>')
            }
            node.appendTo(data.context);
        });
    }).on('fileuploadprocessalways', function (e, data) {
        var index = data.index,
            file = data.files[index],
            node = $(data.context.children()[index]);
        if (file.preview) {
            node
                .prepend('<br>')
                .prepend(file.preview);
        }
        if (file.error) {
            node
                .append('<br>')
                .append($('<span class="text-danger"/>').text(file.error));
        }
        if (index + 1 === data.files.length) {
            data.context.find('button')
                .text('Upload')
                .prop('disabled', !!data.files.error);
        }
    }).on('fileuploadprogressall', function (e, data) {
        var progress = parseInt(data.loaded / data.total * 100, 10);
        $('#progress .progress-bar').css(
            'width',
            progress + '%'
        );
    }).on('fileuploaddone', function (e, data) {
        $.each(data.result.files, function (index, file) {
            if (file.url) {
                var link = $('<a>')
                    .attr('target', '_blank')
                    .prop('href', file.url);
                $(data.context.children()[index])
                    .wrap(link).append($('<span/>').text(file.name));
                $( "#filesHidden" ).append( '<input type="hidden" name="images[]" value="' + file.name + '">' );
            } else if (file.error) {
                var error = $('<span class="text-danger"/>').text(file.error);
                $(data.context.children()[index])
                    .append('<br>')
                    .append(error);
            }
        });
    }).on('fileuploadfail', function (e, data) {
        $.each(data.files, function (index, file) {
            var error = $('<span class="text-danger"/>').text('File upload failed.');
            $(data.context.children()[index])
                .append('<br>')
                .append(error);
        });
    }).prop('disabled', !$.support.fileInput)
        .parent().addClass($.support.fileInput ? undefined : 'disabled');

});

还要记得添加以下内容

  • jquery.ui.widget.js
  • 负载image.min.js
  • jquery.iframe-transport.js
  • jquery.fileupload.js
  • jquery.fileupload-validate-es_ES.js //这只是语言
  • jquery.fileupload.css