jquery ajax post multi dimensional array to php


jquery ajax post multi dimensional array to php

>我有一个下载为 csv 按钮,用于将结果导出为 csv。到目前为止,我一直在为此使用服务器端代码。我正在将选定的下拉ID发送到csvdownload.php页面,该页面正在用excel编写结果。

但是现在,我想要一个实用程序,用于使用复选框选择搜索结果,然后将所选结果写入csv。

我计划获取数组中的表数据,然后使用 ajax 将其发布到 php,然后它将完成其余的事情。但是这怎么可能将多行数据发布到 php。我有以下代码段用于获取警报数据的表数据,但不知道如何将其作为数组并传递给php

      $('#tblSearchResults tr').filter(':has(:checkbox:checked)').each(function() {
     $tr = $(this);
       //alert($tr.find("td").eq(4).html());
        var risk_cat = $tr.find("td").eq(1).html();
        var risk_type = $tr.find("td").eq(2).html();
        var risk_desc = $tr.find("td").eq(3).html();
        var treat_desc = $tr.find("td").eq(4).html();
        var treat_cat = $tr.find("td").eq(5).html();
        selectedData.push({"risk_cat": risk_cat, "risk_type": risk_type, "risk_desc": risk_desc, "treat_desc": treat_desc, "treat_cat": treat_cat});

谢谢

我认为您需要使用JSON.stringify(selectedData)才能在服务器端使用它。

j查询:

var obj = { 'risk_cat': risk_cat, 'risk_type': risk_type };
selectedData.push(obj);
$.post('serive.php', { DTO: JSON.stringify(selectedData) }, 
function(data){ /* handle response,  */ });

服务.php:

header('Content-type: application/json');
header('Cache-Control: no-cache, must-revalidate');
$foo = json_decode($_POST['DTO']);

$arr = array('a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5); //example data
echo json_encode($arr);

这应该让你开始。在您的 ajax 响应中,alert(data.a)会提醒"1"

你应该使用 jQuery 序列化 (http://api.jquery.com/serialize/)

在页面中创建包含<input>字段的<form>,其中包含要传递给服务器的值。

然后,您可以使用jQuery调用服务器:

$.ajax({
  type: 'POST',
  url: url,
  data: yourForm.serialize(),
  success: success,
  dataType: dataType
});

查看 Jquery 表单。您可以将表包装在表单元素中,它将使用 Ajax 将其发布为序列化。http://jquery.malsup.com/form/

也许你可以试试这个:

$.ajax({
  type: 'POST',
  url: yourscript.php,
  data: JSON.stringify(selectedData),
  success: function(..){
  },
  contentType: "application/json"
});

在 PHP 文件中,从标准输入读取 JSON 字符串,并使用 json_decode 解码 JSON。

$requestObject = json_decode(file_get_contents('php://input'));