按名称禁用许多字段 javascript

Disable many fields by name javascript

这是我的问题:

我有一个 jsp 页面,这个 jsp 有很多这样的文本字段:

<html:text property="cicPF" maxlength="9" style="text-transform: uppercase;" onfocus="disableIfeFields()"/>

所以我想在焦点位于特定字段时禁用其中一些文本字段

但是这些字段都没有 "id" 标签,我无法修改它以包含它。

我可以禁用字段使用他们的名字,没有一个重复相同的名字。

例如像这样的函数:

function disableIfeFields(){
    document.getElementsByName("numIdentificacionPF").disabled = true;

}

谢谢

您需要遍历列表并禁用所有您想要的字段,使用输入来显示示例:

function disableIfeFields() {
  document.getElementsByName("numIdentificacionPF").forEach((e) => {
    e.disabled = true;
  });
}
<html:text property="cicPF" maxlength="9" style="text-transform: uppercase;" />
<input onfocus="disableIfeFields()" type="text" name="fname">
<input type="text" name="numIdentificacionPF">
<input type="text" name="numIdentificacionPF">
<input type="text" name="numIdentificacionPF">
<input type="text" name="numIdentificacionPF">
<input type="text" name="numIdentificacionPF">

希望以下内容对您有所帮助。因为选择结果是一个元素列表,所以您必须循环遍历结果。 请注意,由于您说没有输入重复相同的名称,所以我使用 querySelectorAll,毕竟这可能是更合适的方法……

var inputs = document.querySelectorAll('input[type="text"]');
for (var i = 0; i < inputs.length; i++) {
    if (inputs[i].id === 'label') {
        continue;
    }
    inputs[i].disabled = true;
}

可能是这样的:

function disableIfeFields(){
    document.querySelectorAll('[property="cicPF"]')[0].disabled = true;
}

disableIfeFields();
<input type="text" property="cicPF" maxlength="9" style="text-transform: uppercase;" onfocus="disableIfeFields()"/>