单个元素的 Jquery 验证插件 errorplacement

Kri*_*a38 2 html javascript css jquery jquery-validate

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

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

对于城市字段,我的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>
Run Code Online (Sandbox Code Playgroud)

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"},

     }

});
     });
Run Code Online (Sandbox Code Playgroud)

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

Aru*_*hny 6

你错过了 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"
            },

        }

    });
});
Run Code Online (Sandbox Code Playgroud)

演示:小提琴