проверка JQuery - невыделенная проблема - PullRequest
2 голосов
/ 24 мая 2011

У меня есть большая форма проверки, которая работает очень хорошо, за исключением одной проблемы.Дело в том, что у меня есть 2 правила, которые должны входить в один и тот же div (без использования правила, они должны перечисляться отдельно), который будет иметь красную рамку вокруг него / стиль блока.то, что это достигает, является div, который оборачивает 2 кадра.стиль / интервал в порядке.проблема в том, что, когда все поля заполнены, и даже если ошибки нет, мне по-прежнему выделяется небольшое красное поле (стиль div остается как display = block. Так как это мои контейнеры ошибок, не должен отображатьсядинамически изменить на ноль, если поля в нем действительны. Можно ли как-нибудь изменить отображение на «ноль», если поля в этой строке действительны? спасибо большое, я занимался этим несколько дней.

вот код, который я использую (соответствующие части).

function myErrorPlacement(error, element) {
if ((element.attr("id") == "fname") || (element.attr("id") == "lname")) {
  $ms("#billing1_e").append(error) ;
}
if (element.attr("id") == "address") {
   $ms("#billing2_e").append(error) ;
}
if ((element.attr("id") == "city") || (element.attr("id") == "state1") || (element.attr("id") == "zip")) {
   $ms("#billing3_e").append(error) 
}
if ((element.attr("id") == "email") || (element.attr("id") == "emailver")) {
   $ms("#billing4_e").append(error) 
}
if ((element.attr("id") == "pass") || (element.attr("id") == "passver")) {
   $ms("#billing5_e").append(error) 
}
if ((element.attr("id") == "expmonth") || (element.attr("id") == "expyear")) {
   $ms("#billing7_e").append(error) 
}
if (element.attr("id") == "chkOffer") {
   $ms("#billing8_e").append(error) 
}
if (element.attr("id") == "billingCC") {
   $ms("#billing6_e").append(error) 
}

и

$ms("#billingForm").validate({

      highlight: function(element) {

         $ms(element).closest(".BF_Body").next().addClass('billing_e')
      },
    errorContainer: ".billing_e",
            errorPlacement: myErrorPlacement

и css:

.billing_e
{   
position:relative;
float:left;
background-color:#f3e6e6;
border:2px solid #924949;
padding:3px 4PX;
z-index:4;
color:#924949;
font-family:Verdana, Geneva, sans-serif;
font-size:9px;
font-weight:bold;   
}

изменить, извините, вот HTML-код. У меня есть несколько строк, как это. Я получаю плавающее поле справа от div, которое перечисляет ошибки в этой конкретной строке

      <div class="BF_Body" id="billing1">
      <div class="BF_Body_L"><input name="fname"  id="fname" type="text" Title="First Name" maxlength="50" class="textboxpg2" ></div>
      <div class="BF_Body_R"><input name="lname"  id="lname" type="text" Title="Last Name" maxlength="50"  class="textboxpg2" ></div>
  </div>
  <div id="billing1_e" class="billing_e"></div>
  <div class="BF_Body" id="billing2">
    <div class="BF_Body_L"><input name="address" id="address" type="text" title="Address" maxlength="50" class="textboxpg2"></div>
    <div class="BF_Body_R"><input name="address2" id="address2" type="text" Title="Address 2" maxlength="50" class="textboxpg2"></div>
  </div>
  <div id="billing1_e" class="billing_e"></div>

и вот скриншот: http://img.photobucket.com/albums/v385/gefeno/screenshot.jpg

Ответы [ 2 ]

1 голос
/ 26 мая 2011

Вы можете добавить правило невысветого, чтобы изменить цвет div, когда нет ошибки

highlight: function(element) {

         $ms(element).closest(".BF_Body").next().addClass('billing_e')
      },

unhighlight: function (element, errorClass) {

        $ms(element).closest(".BF_Body").next().addClass('success class')            
    }
0 голосов
/ 25 мая 2011

Не уверен, что это сработает, но вы можете попробовать добавить идентификаторы в окна сообщений и перечислить их в вашем .validate ()

Так что вместо:

errorContainer: ".billing_e"

Попробуйте:

errorContainer: "#messageBox1, #messageBox2, ..."

Кажется, это ближе к тому, что показывает пример в документации (http://docs.jquery.com/Plugins/Validation/validate#toptions)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...