我正在使用jQuery,并且希望通过Ajax上传文件。我进行了一些搜索,发现这是不可能的。
然而,有一个jQuery插件jQuery Form Plugin,可以让我们通过Ajax上传文件。
它运行得非常好,但我有一个特殊的问题。以下是我的代码:
$('#question-form').submit(function() {
var serialAnswers = '';
// Create a query string given some fields
// Format of the query string : answers[0][fr_fr][0]=a1fr&answers[0][fr_fr][1]=2&answers[0][en_uk][0]=a1en&answers[0][en_uk][1]=6&...
$('#question-answers > div').each(function(idx, elt) {
$('div[lang]', $(elt)).each(function(idxLang, eltLang) {
var lang = $(this).attr('lang');
serialAnswers += 'answers[' + idx + '][' + lang + '][0]=' + $("[answerpart=display]", $(eltLang)).val();
serialAnswers += '&answers[' + idx + '][' + lang + '][1]=' + $("[answerpart=value]", $(eltLang)).val() + '&';
});
});
$(this).ajaxSubmit({
datatype: "html",
type: "POST",
data: serialAnswers,
url: $(this).attr("action"),
success: function(retour) {
$('#res-ajax').html(retour);
}
});
return false;
});
如您所见,我需要将
$.ajax
调用替换为一个带有相同选项的$(this).ajaxSubmit()
调用。此外,我需要根据一些字段创建一个查询字符串(代码中的serialAnswers),并将其传递给PHP代码。当我没有文件要上传时,我曾经这样做。我只是序列化表单字段并添加了名为serialAnswers的查询字符串:
$.ajax({
datatype: "html",
type: "POST",
data: $(this).serialize() + '&' + serialAnswers,
url: $(this).attr("action")
success: function(retour) {
$("#res-ajax").html(retour);
}
});
但是我的问题是,表单插件以这种方式传输我的附加数据(查询字符串)(在PHP文件中):
Array
(
[question_heading_fr_fr] => something
[question_heading_en_uk] => nothing
[question_type] => 5
[0] => a
[1] => n
[2] => s
[3] => w
[4] => e
[5] => r
[6] => s
[7] => [
[8] => 0
[9] => ]
[10] => [
[11] => f
[12] => r
[13] => _
[14] => f
[15] => r
[16] => ]
....
)
根据文档,我需要将一个JSON对象传递给数据选项,如下所示:
data: { key1: 'value1', key2: 'value2' }
但我不知道如何将我的查询字符串转换为JSON对象,如果在PHP端解释为数组会怎样。
有解决方案吗?
编辑:即使我使用一个iframe,我也不知道如何添加一个查询字符串,其中的信息并不来自表单(来自上面代码中的serialAnswer
)。