选中复选框时获取td中的值


Get values in td when checkbox is marked

我有一个从个人那里获取地址的查询。数据显示在表格中:

echo "<div id='rightcontent'><table id='one-column-emphasis'>";
echo "<th><input type='checkbox' name='csv_all' id='csv_all'></th><th>Namn</th><th>Adress</th><th>Adress2</th><th>Adress3</th><th>Personnummer</th><th>Telefonnummer</th><th>Telefonnummer2</th>";
$antal_sidor = round($obj->search->wp->totalHits / $obj->search->wp->pageSize); 
foreach($obj->search->wp->features as $fish) //Loopar ut 50st (pageSize)
{
    echo "<tr>";
    echo "<td><input type='checkbox' value='csv' class='csv'></td>";
    echo "<td>" . $fish->name . "</td>";
    foreach($fish->addresses as $ad)
    {
        echo "<td>" . $ad->label . " " . $ad->postcode . " " . $ad->area . "</td>";
    }   
    if(!empty($fish->dateOfBirth))
    {
        echo "<td>" . $fish->dateOfBirth . "</td>";
    }   
    if(!empty($fish->phoneNumbers))
    {
        foreach($fish->phoneNumbers as $ph)
        {
            echo "<td>" . $ph . "</td>";
        }
    }       
    echo "</tr>";
}
echo "</table>";

如您所见,行中列出了一个复选框字段。其目的是标记所有复选框,然后将地址导出到CSV。但是,当我选中所有复选框时,我如何获得td的值、地址?

缺少详细信息,在发送表单时,您想用javascript在客户端执行此操作,还是用PHP在服务器端执行此操作?对于服务器端,您需要在复选框输入中添加一个名称,该字段将与其值一起发送到PHP。对于客户端,您可以先在DOM中插入数据,然后使用jQuery查找已检查的输入并检索数据。

foreach($obj->search->wp->features as $fish) //Loopar ut 50st (pageSize)
{
    echo "<tr data-phone-numbers='" . json_encode($fish->phoneNumbers) . "' data-addresses='" . json_encode($fish->addresses) . "'>";
    echo "<td><input type='checkbox' value='csv' class='csv'></td>";
    echo "<td>" . $fish->name . "</td>";
...

然后使用jQuery只需收集检查的输入并找到编码的地址:

var addressList = [];
$("input[type='checkbox']:checked").each(function(){
    addressList.push({
        "phones": JSON.parse($(this).closest("tr").data("addresses")),
        "addresses": JSON.parse($(this).closest("tr").data("phone-numbers"))
    });
});
//addressList now is an array phones and addresses objects for all the checked items

顺便说一句,我不知道你的代码将如何生成格式良好的表单元格,因为TR中有不可预测的TD数量。你可能需要重新评估你的表结构,以确保每行都有固定数量的单元格。

这是一个功能齐全的版本,它从选中的行创建CVS,此外,它还从PHP中获取JSON,而不是通过网络发送表

实时演示

$("#csv_all").on("click", function () {
    $(".csv").prop("checked", this.checked);
});
$("#makeCsv").on("click", function () {
    var csv = [];
    $(".csv:checked").each(function () {
        var row = [];
        $(this).parent().siblings().each(function () { // all TDs
            row.push('"' + $(this).text() + '"');
        });
        if (row.length > 0) csv.push(row.join(","));
    });
    $("#csv").val(csv.length > 0?csv.join("'n"):"");
});