试图从 jQuery 生成一个数组:checked 选择器

Posted

技术标签:

【中文标题】试图从 jQuery 生成一个数组:checked 选择器【英文标题】:Trying to generate an array from jQuery :checked selector 【发布时间】:2013-12-07 14:03:47 【问题描述】:

我有一张这样的桌子:

<tr class="row">
    <td class="row-checkbox-delete-row">
        <input tabindex="-1" class="checkbox-delete-row" type="checkbox" />
    </td>
    <td class="row-target">10</td>
    <td class="row-product-id">
        <input class="id-target row-product-id" name="lineItem[0].originalInput" type="text" data-ajax-line-id="1" />
    </td>
    <td class="row-qty">
        <input class="qty-target row-qty" name="lineItem[0].quantity" type="text" value="1" />
    </td>
    <td class="row-description"></td>
    <td class="row-abc6"></td>
    <td class="row-abc8">
        <input readonly tabindex="-1" class="abc8-target row-abc8" name="lineItem[0].abc8" type="text" />
    </td>
    <td class="row-upc"></td>
    <td class="row-ndc"></td>
</tr>
<tr class="row">
    <td class="row-checkbox-delete-row">
        <input tabindex="-1" class="checkbox-delete-row" type="checkbox" />
    </td>
    <td class="row-target">30</td>
    <td class="row-product-id">
        <input class="id-target row-product-id" name="lineItem[0].originalInput" type="text" data-ajax-line-id="2" />
    </td>
    <td class="row-qty">
        <input class="qty-target row-qty" name="lineItem[0].quantity" type="text" value="1" />
    </td>
    <td class="row-description"></td>
    <td class="row-abc6"></td>
    <td class="row-abc8">
        <input readonly tabindex="-1" class="abc8-target row-abc8" name="lineItem[0].abc8" type="text" />
    </td>
    <td class="row-upc"></td>
    <td class="row-ndc"></td>
</tr>
<tr class="row">
    <td class="row-checkbox-delete-row">
        <input tabindex="-1" class="checkbox-delete-row" type="checkbox" />
    </td>
    <td class="row-target">10</td>
    <td class="row-product-id">
        <input class="id-target row-product-id" name="lineItem[0].originalInput" type="text" data-ajax-line-id="3" />
    </td>
    <td class="row-qty">
        <input class="qty-target row-qty" name="lineItem[0].quantity" type="text" value="1" />
    </td>
    <td class="row-description"></td>
    <td class="row-abc6"></td>
    <td class="row-abc8">
        <input readonly tabindex="-1" class="abc8-target row-abc8" name="lineItem[0].abc8" type="text" />
    </td>
    <td class="row-upc"></td>
    <td class="row-ndc"></td>
</tr>

我有一个这样的变量语句:

var lineids = $(".checkbox-delete-row:checked").parents("td").siblings(".row-product-id").find(".id-target").attr("data-ajax-line-id");

我正在尝试收集所有 data-ajax-line-id 属性并将它们放入一个数组而不循环整个事物(使用类似于我上面的 jQuery 选择器的东西)但现在它返回未定义。

我做错了什么?

【问题讨论】:

【参考方案1】:

试试.map()

var arr = $(".checkbox-delete-row:checked").closest("tr").find(".row-product-id .id-target").map(function() 
    return $(this).attr("data-ajax-line-id");
).get();


要么
var arr = $(".checkbox-delete-row:checked").closest("tr").find("input.id-target").map(function() 
    return $(this).attr("data-ajax-line-id");
).get();

var arr = $(".checkbox-delete-row:checked").closest("tr").find("input.id-target").map(function() 
    return $(this).data("ajax-line-id");
).get();

【讨论】:

以上是关于试图从 jQuery 生成一个数组:checked 选择器的主要内容,如果未能解决你的问题,请参考以下文章

从普通 JS 或 JQuery 中的数组生成消息

jquery设置按钮disabled

使用jQuery从数组数组动态生成<table>时如何排除ID列

jquery easyui datagrid 获取Checked选择行(勾选行)数据

试图从数组中生成所有排列,但只得到一个小子集

如何使 jQuery 函数迭代从同一类中的 2 个列表中获取的单独数组?