javascript - 尝试仅针对选中的行通过基于 $(this) 元素和 jQuery 的元素进行迭代

标签 javascript jquery arrays loops

我动态创建了多行:

<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>

我想遍历所有这些并获取每个属性 data-ajax-line-id

我有这段代码,但它不起作用。需要一些帮助。

var lineids = new Array();

$(".checkbox-delete-row:checked").each(function() {
    lineids.push($(this).parents("td").siblings(".row-product-id").children(".id-target").attr("data-ajax-line-id"));
});

最佳答案

然后遍历行,检查该行中是否选中了 .checkbox-delete-row ,如果是,则从该行获取 data 属性并将其添加到数组中,如果不只是返回 null :

var arr = $.map($('.row'), function(el) { 
    return $('.checkbox-delete-row', el).is(':checked') ? 
         $('[data-ajax-line-id]', el).data('ajax-line-id') :
         null; 
});

关于javascript - 尝试仅针对选中的行通过基于 $(this) 元素和 jQuery 的元素进行迭代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20154898/

相关文章:

javascript - 在 JavaScript 中从文本字段获取输入后如何写入文本字段?

php - 查找对应数组值的键

c - 尝试将文本文件加载到数组中,出现段错误。有什么想法吗?

php - 如何根据两个键对数组求和(小计)?

javascript - 在 google Maps API V3 中,如何在不使用限制平移解决方案的情况下防止标记在 x 轴上重复?

javascript - element.html() 在 DOM 就绪时返回空

javascript - 仅在 bootstrap formhelpers 国家选择器中显示国家子集文本

javascript - 如何仅在视口(viewport)中显示数据

javascript - IIFE 和带有 setInterval plain JS 的箭头函数

javascript - 如何从字符串中获取数值?