Как избежать отправки полей ввода, которые скрыты при отображении: none для сервера?

Представьте, что у вас есть форма, в которой вы переключаете видимость нескольких полей. И если поле не отображается, вы не хотите, чтобы его значение находилось в запросе.

Как вы справляетесь с этой ситуацией?

Ответ 1

Установка элемента формы для отключения остановит его на сервере, например:

<input disabled="disabled" type="text" name="test"/>

В javascript это будет означать что-то вроде этого:

var inputs = document.getElementsByTagName('input');
for(var i = 0;i < inputs.length; i++) {
    if(inputs[i].style.display == 'none') {
        inputs[i].disabled = true;
    }
}
document.forms[0].submit();

В jQuery:

   $('form > input:hidden').attr("disabled",true);
   $('form').submit();

Ответ 2

Вы можете использовать javascript для установки отключенного атрибута. Вероятно, самое лучшее место для этого - событие нажатия кнопки "отправить".

Однако я бы посоветовал не делать этого вообще. Если возможно, вы должны отфильтровать свой запрос на сервере. Это будет более надежным.

Ответ 3

Если вы хотите отключить все элементы или определенные элементы в скрытом родительском элементе, вы можете использовать

$("div").filter(":hidden").children("input[type='text']").attr("disabled", "disabled");

В этом примере http://jsfiddle.net/gKsTS/ отключает все текстовые поля в скрытом div

Ответ 4

Как насчет:

$('#divID').children(":input").prop("disabled", true); // disable

и

$('#divID').children(":input").prop("disabled", false); // enable

Чтобы переключить все дочерние входы (выбор, флажки, ввод, текстовые поля и т.д.) внутри скрытого div.

Ответ 5

Одно очень простое (но не всегда самое удобное) решение - удалить атрибут "name" - стандарт требует, чтобы браузеры не отправляли неназванные значения, и все браузеры, которые я знаю, придерживаются этого правила.

Ответ 6

Я бы либо удалил значение из ввода, либо отсоединил входной объект от DOM, чтобы он не существовал для публикации в первую очередь.