Вот отрывок из JQuery:JQuery AUTORESIZE ломает форму проверки для прокручиваемым
$(document).ready(function() {
$('textarea').autoResize();
$('#submitSurvey').click(function() {
- Пропуск нескольких линий -
$("input[id$='Buggy']:radio:checked").each(function() {// If any radio buttons are marked "Buggy" and no comment is left, require comment
var parent = $(this).parent().get(0);// parent element of the radio button
var nextCommentDiv = $(parent).nextAll('.comments').get(0);
var txtarea = $(nextCommentDiv).children('.itemComment').get(0);// comment for the radio button marked "Buggy"
var surroundingDiv = $(parent).parent().get(0);
var heading = $(surroundingDiv).prev();// section title
if(txtarea.value == '' || txtarea.value == 'Type comments here') {
$(txtarea).addClass('invalid');
$(heading).addClass('redtext');
valid = false;
}
});
});
});
Вот фрагмент HTML-кода:
<div class="subQ">Question 1</div>
<div class="ratings">
<input type="radio" name="item1" id="item1Works" value="Works" /><label for="item1Works"> Works </label>
<input type="radio" name="item1" id="item1Buggy" value="Buggy" /><label for="item1Buggy"> Buggy </label>
<input type="radio" name="item1" id="item1na" value="Not Tested" /><label for="item1na"> Didn't Test</label>
</div><br />
<div class="subQ">Question 2</div>
<div class="ratings">
<input type="radio" name="item2" id="item2Works" value="Works" /><label for="item2Works"> Works </label>
<input type="radio" name="item2" id="item2Buggy" value="Buggy" /><label for="item2Buggy"> Buggy </label>
<input type="radio" name="item2" id="item2na" value="Not Tested" /><label for="item2na"> Didn't Test</label>
</div><br />
<div class="subQ">Question 3</div>
<div class="ratings">
<input type="radio" name="item3" id="item3Works" value="Works" /><label for="item3Works"> Works </label>
<input type="radio" name="item3" id="item3Buggy" value="Buggy" /><label for="item3Buggy"> Buggy </label>
<input type="radio" name="item3" id="item3na" value="Not Tested" /><label for="item3na"> Didn't Test</label>
</div><br />
<div class="comments">
<textarea class="itemComment" name="itemsComment" id="itemsComment" rows="1">Type comments here</textarea>
</div>
Обратите внимание, что может быть несколько вопросов в группе с одним полем комментариев. Проверка проверяет группу на любые радиокнопки с надписью «Багги», и если она находит ее, тогда она помещает красную рамку вокруг поля комментария, чтобы потребовать от пользователя прокомментировать область с ошибкой (форма для бета-тестеров настольного приложения).
По какой-то причине, когда я добавляю autoResize ко всем моим текстовым полям, строка $ (txtarea) .addClass ('invalid') в моей проверке больше не работает (но следующая строка $ (заголовок). addClass ('redtext') работает). Я не получаю никаких ошибок в Firefox или Firebug. Я уверен, что мой код немного неуклюжий, я новичок в jquery, поэтому многие селектора обхода DOM - это просто «что сработало».
Вот ссылка на autoResize jquery plugin.
Любые предложения?
Я новичок в Javascript и JQuery, так что не дает мне слишком трудно время о моем любительском коде :)
Есть ли особая причина, по которой у вас есть .get (0) в конце ваших выборов? – Mark
Ха, если честно, я не знаю. Как и мои сообщения, это то, что сработало для меня, пытаясь несколько разных способов выбрать эти элементы. Сначала я попытался объединить все эти строки в одну строку, которая выбрала бы родительский родительский родительский класс с классом «itemComment», но это не сработало. Затем я попытался разбить его на отдельные строки, где каждый из них был назначен переменной. Это не сработало, пока я не использовал .get (0). Любые предложения по очистке моего кода будут высоко оценены, независимо от того, отвечает ли он на мой первоначальный вопрос! – Josh