0

我正在尝试对 JSON 数组进行编码并将其发送到 php 页面并将其添加到 mysql:

var data = $('form').serialize();
$.ajax({
    type: 'POST',
    url: 'naujas.php',
    dataType: 'json',
    data: ({
        json: JSON.stringify(data)
    }),
    success: function () {
        $('#naujas').load('naujas.php');
    }
});

但我认为它不起作用我从 php 得到这样的响应:pav=1&ppav=2&kiekis=3&kaina=4d&ppav=5&kiekis=6&kaina=7&ppav=8&kiekis=9&kaina=0

.php 文件

<?php
    $json = json_decode($_POST['json']);
    echo $json;
?>

我做错了什么?

4

3 回答 3

1

试试这样:

var data = $('form').serializeArray().reduce( function(obj,cur){
    obj[cur.name] = cur.value;
    return obj;
},{});

说明

  • .serializeArray()返回一个数组,其结构如下:

    [ {name:"inputname1",value:"inputvalue1"},
      {name:"inputname2",value:"inputvalue2"},
      //---------------------------------------
      {name:"inputnamen",value:"inputvaluen"} ]
    
  • .reduce()函数将该数组转换为对象:

    { "inputname1":"inputvalue1",
      "inputname2":"inputvalue2",
      //---------------------------------------
      "inputnamen":"inputvaluen" }
    
于 2012-07-11T19:03:31.090 回答
0

dataType: 'json'已经告诉 jQuery 以 json 格式发布数据。

您需要做的就是发布您的数据,如下所示:

data: (data),

问题来自将您的对象转换为字符串表示形式(字符串化)。

于 2012-07-11T19:07:31.187 回答
0

您可能需要使用 php stripslashes

http://php.net/manual/en/function.stripslashes.php

我认为它是这样的

json_decode(stripslashes($_POST['json']));
于 2012-07-11T19:20:33.190 回答