单个元素的Jquery验证插件错位

时间:2015-03-04 10:58:07

标签: javascript jquery html css jquery-validate

我正在使用Jquery验证插件来验证表单。当验证表单时,一个元素对齐是不正确的。

如果您看到图片,则在验证表单时,城市字段图标+ 按钮对齐不正确。因为标签错误验证显示在输入元素和图标+ 之间。我需要在元素下面显示错误消息。

我的html代码对于城市字段是这样的

    <tr>
        <td align="right"><span class="mandetry">*</span> City:</td>
         <td>
       <div class="input-group" id="app_details">
      <input type="text" class="form-control client_city" name="client_city" id="city_name" value="<?php echo set_value('client_city')?>"> 
     <span class="input-group-btn">
     <a class="btn btn-default" id='addnewcity' href="<?php echo base_url('addnewcity')?>"><i class="fa fa-plus-square"></i></a>
     </span>
   <div id="messageBox"></div> <!-- Here i would like to display message-->
    </div> </tr>

js代码就像这样

$(document).ready(function(){
$('#add_client').validate({
    errorClass: 'validation_errors',
    debug: false,
     rules: {
         client_name:{required:true},
         client_address:{required:true},
         client_city:{required:true},
         errorPlacement: function(error, element) {
                if (element.attr("name") == "client_city" )
                {
                    error.appendTo("#messageBox");
                }
            }
     },
     messages: {
         client_name:{required:"The Client name is a required / mandatory field"},
         client_address:{required:"The Client address is a required / mandatory field"},
         client_city:{required:"The City is a required / mandatory field"},

     }

});
     });

错误消息未附加到 messageBox div 。在js中 errorPlacement 有任何错误。仅对于 city 元素,我需要正确显示错误消息。对于其他表单字段,它不应该更改。我无法解决此问题。请建议我。谢谢。

1 个答案:

答案 0 :(得分:3)

您缺少else部分,如果它不是client_city元素,那么您需要在

之后插入错误
$(document).ready(function () {
    $('#add_client').validate({
        errorClass: 'validation_errors',
        debug: false,
        rules: {
            client_name: {
                required: true
            },
            client_address: {
                required: true
            },
            client_city: {
                required: true
            }
        },
        errorPlacement: function (error, element) {
            console.log('dd', element.attr("name"))
            if (element.attr("name") == "client_city") {
                error.appendTo("#messageBox");
            } else {
                error.insertAfter(element)
            }
        },
        messages: {
            client_name: {
                required: "The Client name is a required / mandatory field"
            },
            client_address: {
                required: "The Client address is a required / mandatory field"
            },
            client_city: {
                required: "The City is a required / mandatory field"
            },

        }

    });
});

演示:Fiddle