>我有一个下载为 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'));