通过名称或 ID 的一部分获取元素

IT技术 javascript forms
2021-02-19 18:24:38

这是我的表单示例(只有我想要的输入,但还有很多其他输入):

<form name="inputform" action="..." method="post">
    <input type="hidden" name="id_qtedje_77" id="id_qtedje_77" value="0">
    <input type="text" id="id_qte_77" name="prestation_detail_fields[77][qte_collecte]" value="0.00">
    <input type="text" id="id_rec_77" name="prestation_detail_fields[77][reliquat_conforme]" value="0.00">
    <input type="text" id="id_ren_77" name="prestation_detail_fields[77][reliquat_non_conforme]" value="0.00">
    <input type="checkbox" name="prestation_detail_fields[77][dechet_non_present]" value="1">
    
    <!-- another TR -->
    
    <input type="hidden" name="id_qtedje_108" id="id_qtedje_108" value="0">
    <input type="text" id="id_qte_108" name="prestation_detail_fields[108][qte_collecte]" value="0.00">
    <input type="text" id="id_rec_108" name="prestation_detail_fields[108][reliquat_conforme]" value="0.00">
    <input type="text" id="id_ren_108" name="prestation_detail_fields[108][reliquat_non_conforme]" value="0.00">
    <input type="checkbox" name="prestation_detail_fields[108][dechet_non_present]" value="1">
</form>

我想要的是获取输入的值,但由于表单是用 PHP 构建的,我不知道行标识符 (77, 108)。

有没有办法做类似的事情getElementByName('id_qtedje_%')

注意:我没有使用任何库,也不打算使用任何库。

2个回答

您最好的选择可能是document.querySelectorAll,您可以使用任何 CSS 选择器,包括“属性开头为”选择器,input[id^="id_qtedje_"]. 所有现代浏览器以及 IE8 都支持

var elements = document.querySelectorAll('input[id^="id_qtedje_"]');

如果您只想要第一个匹配项(而不是列表),则可以document.querySelector改用。它返回对文档顺序中第一个匹配项的引用,或者null如果没有匹配项。

或者,您可以为元素指定一个类名,然后使用document.getElementsByClassName,但请注意,虽然getElementsByClassName旧版本的 Chrome 和 Firefox 支持,但IE8 没有它,因此它不像querySelectorAll现代中更有用的那样受支持时代。

var elements = document.getElementsByClassName("theClassName");

如果您使用任何库(jQuery、MooTools、Closure、Prototype 等),它们很可能有一个函数,您可以使用它来通过几乎任何 CSS 选择器查找元素,用它们自己的代码填补浏览器支持的空白. 例如,在 jQuery 中,它是$( jQuery) 函数;在 MooTools 和 Prototype 中,它是$$.

您可以jQuery 中使用带有选择器开头

var listOfElements = $('[name^="id_qtedje_"]')

您可能还对包含选择器结尾感兴趣


使用querySelectorAll,你可以做

document.querySelectorAll('[name^="id_qtedje_"]')

或者:

假设所有元素都是inputs,你可以使用这个:

function getElementByNameStart(str) {
    var x=document.getElementsByTagName('input')
    for(var i=0;i<x.length;i++) {
        if(x[i].indexOf(str)==0) {
            return x[i];
        }
    }
}

可以称为 getElementByNameStart("id_qtedje_")

请注意,这仅返回此类型第一个元素。全部返回:

function getElementByNameStart(str) {
    var x=document.getElementsByTagName('input')
    var a=[];
    for(var i=0;i<x.length;i++) {
        if(x[i].indexOf(str)==0) {
            a.push(x[i])
        }
    }
    return a;
}

如果元素是任何类型,请将“输入”替换为“*”(请注意,这可能会使您的代码变慢)

这是对这个问题的一个非常好的答案,我不知道为什么有人投票否决了这个问题。真的没有更好的方法来做到这一点。
2021-04-24 18:24:38
@marksyzm:我认为这与我最初的(意外)提交有关。看到第一个修订版,我还没有打完,我就按了提交按钮。:S 这没什么大不了的,只是一个downvote :)
2021-05-13 18:24:38
@marksyzm 因为有人不想要 jQuery 的问题。
2021-05-14 18:24:38