Я использую плагин JQuery Validation, и моя цель - чтобы к меткам недопустимых полей был применен класс ошибок.Мне удалось это сделать, но моя проблема в том, что JQuery перезаписывает существующий класс метки, а не добавляет к нему класс ошибок.
Вот JQuery:
<script src="<?php bloginfo('template_directory'); ?>/js/lib/jquery.js" type="text/javascript"></script>
<script src="<?php bloginfo('template_directory'); ?>/js/jquery.validate.js" type="text/javascript"></script>
<script>
$(document).ready(function(){
$("#profile-basic").validate({
debug:true,
highlight: function(element, errorClass, validClass) {
$(element).addClass(errorClass).removeClass(validClass);
$(element.form).find("label[for=" + element.id + "]")
.addClass(errorClass);
},
unhighlight: function(element, errorClass, validClass) {
$(element).removeClass(errorClass).addClass(validClass);
$(element.form).find("label[for=" + element.id + "]")
.removeClass(errorClass);
}
});
});
</script>
Выделение и невыделениеварианты пришли с веб-сайта JQuery.(http://docs.jquery.com/Plugins/Validation/validate)
Вот HTML - рассматриваемые элементы являются меткой и выбираются для categoryID:
<form method="post" action="" class="bullhorn" id="profile-basic">
<div id="accordion"> <!-- Accordion is currently disabled -->
<h3>Name*</h3>
<div>
<div class="twocol">
<label for="firstName">First Name:*</label>
<input type="text" id="firstName" name="firstName" class="required" />
<label for="middleName">Middle Name:</label>
<input type="text" id="middleName" name="middleName" />
<label for="lastName">Last Name:*</label>
<input type="text" id="lastName" name="lastName" class="required" />
</div>
<div class="twocol">
<label for="categoryID" class="ownline">Please select your primary category:*</label>
<select name="categoryID" id="categoryID" class="required">
<option value="">Category 1</option>
<option value="">Category 2</option>
<option value="">Category 3</option>
<option value="">Category 4</option>
<option value="">Category 5</option>
<option value="">Category 6</option>
<option value="">Category 7</option>
<option value="">Category 8</option>
<option value="">and so on</option>
</select>
</div>
</div><!-- name -->
</div>
<div class="buttons"><input type="submit" value="Save and Go to Work History"/><input type="submit" value="Save"/></div>
</form>
Обратите внимание, что аккордеон в настоящее время отключен - закомментирован полностью.
И соответствующий CSS:
label { float:left; text-align:right; width:30%; margin:0 14px 14px 0; line-height:20px; font-weight:bold; }
input, select, textarea { float:left; width:63%; margin-bottom:14px; background:#eee; line-height:1; }
input[type=submit], input[type=reset] { float:right; display:block; width:auto; margin:20px 0 0 14px; }
input:focus, textarea:focus { background:#fff; }
input, textarea { padding:2px 4px; }
select option { text-transform:capitalize; }
textarea { height:49px; }
.ownline { text-align:left; width:100%; line-height:20px; font-weight:bold; margin-bottom:3px; }
.ownline+input, .ownline+select, .ownline+textarea, .ownline+.fieldinstructions+select { width:100%; }
label.error { color:#8e082d; }
label.error:before { content: "\00bb\00a0"; display:inline-block; text-indent:-10px; }
input.error { border:2px solid #8e082d; background-color:#fdf5f3; }
Когда я отправляю форму (без заполненных полей, чтобы генерировать ошибки) Класс ownline на ярлыке categoryID удаляется и заменяетсяпо классу error . По крайней мере, так оно и есть. Когда я просматриваю источник страниц, метка categoryID выглядит так: ниже. (Я убрал опцию select для краткости.)
<label for="categoryID" class="ownline">Please select your primary category:*</label>
<select name="categoryID" id="categoryID" class="required">
</select>
Но в Firebug это выглядит так:
<label class="error" for="categoryID">Please select your primary category:*</label>
<select id="categoryID" class="required error" name="categoryID">
</select>
Интересно, что JQuery переписал существующий класс в метке, но добавлен к существующему классу в select.
В случаеэто была проблема специфичности CSS, я тестировал написание стилей ownline с label.ownline в качестве селектора, но он не решил ее.
Это сайт WordPress с установленной Контактной формой 7, но Я добавил функцию в functions.php, чтобы контактная форма не вызывала ее содержимое на рассматриваемой странице .
Я гуглял это часами.
Яопределенно нуб JQuery.Я хотел бы помочь, но, пожалуйста, говорите медленно.:)
Спасибо, Ким