实时文件上传

Live file upload

本文关键字:文件 实时      更新时间:2023-09-26

我正在进行jQuery实时文件上传。

我的应用程序中有一个带有文件字段的表单。当用户选择一个文件时,我需要使用AJAX文件上传方法上传它。稍后,当用户在"提交"上提交时,将进行真正的文件上传。

使用以下内容,我的AJAX文件上传进行得很完美。但问题是,文件上传后,文件字段的值将被清除。

var url = $('#site').val()
url = url + "/ajax/addTmpImg";
var id = 'my_file';
alert($('#' + id).val()); // THIS WILL SHOW FILE FIELD VALUE
$.ajaxFileUpload({
    url: url,
    secureuri: false,
    fileElementId: id,
    dataType: 'json',
    data: {
        'type': file_name,
        'name': file_name
    },
    success: function (data, status) {
        alert($('#' + id).val()); // THIS WILL RETURN EMPTY
    },
    error: function (data, status, e) {
        alert(status);
    }
});

在文件上传之前,这将提醒文件字段的值,而在文件上传之后,这样做将不会显示任何内容。

尝试定义一个全局变量并将值$('#'+id).val()分配给该变量。

像这样:

var someVar = $('#'+id).val();

您可以稍后访问该变量。

var url = $('#site').val();
url = url + "/ajax/addTmpImg";
var id = 'my_file';
var val = $('#' + id).val();
alert(val); // THIS WILL SHOW FILE FIELD VALUE
$.ajaxFileUpload({
    url: url,
    secureuri: false,
    fileElementId: id,
    dataType: 'json',
    data: {
        'type': file_name,
        'name': file_name
    },
    success: function (data, status) {

        alert(val); // THIS WILL SHOW FILE FIELD VALUE
    },
    error: function (data, status, e) {
        alert(status);

    }
});