Представьте, что у вас есть форма, в которой вы переключаете видимость нескольких полей. И если поле не отображается, вы не хотите, чтобы его значение находилось в запросе.
Как вы справляетесь с этой ситуацией?
Представьте, что у вас есть форма, в которой вы переключаете видимость нескольких полей. И если поле не отображается, вы не хотите, чтобы его значение находилось в запросе.
Как вы справляетесь с этой ситуацией?
Установка элемента формы для отключения остановит его на сервере, например:
<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();
Вы можете использовать javascript для установки отключенного атрибута. Вероятно, самое лучшее место для этого - событие нажатия кнопки "отправить".
Однако я бы посоветовал не делать этого вообще. Если возможно, вы должны отфильтровать свой запрос на сервере. Это будет более надежным.
Если вы хотите отключить все элементы или определенные элементы в скрытом родительском элементе, вы можете использовать
$("div").filter(":hidden").children("input[type='text']").attr("disabled", "disabled");
В этом примере http://jsfiddle.net/gKsTS/ отключает все текстовые поля в скрытом div
Как насчет:
$('#divID').children(":input").prop("disabled", true); // disable
и
$('#divID').children(":input").prop("disabled", false); // enable
Чтобы переключить все дочерние входы (выбор, флажки, ввод, текстовые поля и т.д.) внутри скрытого div.
Одно очень простое (но не всегда самое удобное) решение - удалить атрибут "name" - стандарт требует, чтобы браузеры не отправляли неназванные значения, и все браузеры, которые я знаю, придерживаются этого правила.
Я бы либо удалил значение из ввода, либо отсоединил входной объект от DOM, чтобы он не существовал для публикации в первую очередь.