0

我似乎无法让这个对象通过 jQuery 的 ajax 传递给我的 PHP 文件。

$("body").on("submit", ".upload-results-form", function(){

        var photosJSON = [];

$(".upload-result-wrapper .upload-results .photos li").each(function(){

    var photoID = $(this).attr("rel");
    var description = $(".photo-upload-description", this).val();
    var source = $("img", this).attr("src");

    photosJSON.push({photoID: photoID, description: description, source: source});

});

var jsonData = JSON.stringify(photosJSON);


    $.ajax({
    type: "POST",
    url: "ajax/add/albums/photos_publish.php",
data: "photosJSON="+jsonData,
    cache: false,
    success: function(html){
        alert(html);        
    }
    });

}); 

我的 jsonData 看起来像这样:

[{"photoID":"47","description":"","source":"photos/50611a8725cca_224.jpg"},
{"photoID":"48","description":"","source":"photos/50611a8764881_224.jpg"},
{"photoID":"49","description":"","source":"photos/50611a87aa508_224.jpg"},
{"photoID":"50","description":"","source":"photos/50611a88dd34b_224.jpg"}]

和我的 php 文件:

$photosJSON = json_decode($_POST['photosJSON']);
echo $photosJSON['photoID'];

但是什么都没有返回,似乎没有任何东西被发送到php。

4

2 回答 2

1

您必须将 javascript 对象转换为 JSON:

data: {photoDescriptions: JSON.stringify(photoDescriptions)},

然后,在您的 PHP 代码中:

$photoDescriptions = json_decode($_POST['photoDescriptions']);
于 2012-09-25T04:38:37.383 回答
1

首先要做的事情是:AJAX 调用的“数据”属性需要是一个对象,就像 timidboy 说的那样。

两个快速的健全性检查:

console.log(photosJSON);

在 .each() 结束之后,并且

var_dump($_POST);

在您的 PHP 页面中的某个位置。我怀疑,假设您遵循 timidboy 的更正,问题不在于您的 AJAX。例如,您确定 each() 迭代的标识符实际上与页面上的 DOM 元素匹配吗?

于 2012-10-31T10:11:40.420 回答