繁体   English   中英

jQuery 验证插件错误放置复选框

[英]jQuery Validation plugin errorPlacement for checkbox

我使用 jQuery 验证插件来验证我的表单。 我的问题是复选框的错误消息的位置。 请看这张图片:

在此处输入图片说明

这是与复选框 + jQuery 验证相关的 html 部分:

<fieldset id = "q8"> <legend class="Q8"></legend>
<label> What are your favourite genres of movies?<span>*</span></label>
<div class="fieldset content"> 

<style type="text/css">
 .checkbox-grid li {
 display: block;
 float: left;
 width: 25%;
}     
</style>

<ul class="checkbox-grid">
<li><input type="checkbox" name="q8[]" value="Action"><label for="checkgenre[]">Action</label></li>
<li><input type="checkbox" name="q8[]" value="Adventure"><label for="checkgenre[]">Adventure</label></li>
<li><input type="checkbox" name="q8[]" value="Comedy"><label for="checkgenre[]">Comedy</label></li>
<li><input type="checkbox" name="q8[]" value="Animation"><label for="checkgenre[]">Animation</label></li>
<li><input type="checkbox" name="q8[]" value="Drama"><label for="checkgenre[]">Drama</label></li> 
<li><input type="checkbox" name="q8[]" value="Romance"><label for="checkgenre[]">Romance</label></li>
  //Continued the same for OTHER CHECKBOXES 

</div>
</fieldset>
 
  //html for other questions...

 <input class="mainForm" type="submit" name="continue" value="Save and Continue" />  

</form>

<script src="http://jqueryvalidation.org/files/dist/jquery.validate.min.js"></script>
<script src="http://jqueryvalidation.org/files/dist/additional-methods.min.js"></script>

<script>
$(document).ready(function() {

 $('#form2').validate({ // initialize the plugin
    errorLabelContainer: "#messageBox",
    wrapper: "li",
   
    rules: {
       "q8[]": {
            required: true,
        },
       "q9[]": {
            required: true,
        },
        q10: {
            required: true,
        },
        q11: {
            required: true,
        },
        q12: {
            required: true,
        }

    },

      errorPlacement: function(error, element) {

      if (element.attr("type") == "radio") {
         error.insertBefore(element);
       } else {
         error.insertBefore(element);
         
    }
   }

 }); 
});
</script>

如果可以解决此问题或在问题旁边显示错误消息(适用于所有输入类型),有人可以帮助我吗? (我的意思是与问题完全相同的行,在 * 之后)??

谢谢

我为您的问题在label添加了一个class ,以便更轻松地找到...

<label class="question">What are your favourite genres of movies?<span>*</span></label>

然后你只需要练习你的“DOM遍历”技术。 研究这里的方法。

  • $(element).parents('div')查找elementdiv容器。

  • 然后.prev($('.question'))你到.question ,它是这个div的第一个前一个兄弟。

将它们放在一起,它会在问题之后立即插入错误消息。

error.insertAfter($(element).parents('div').prev($('.question')))

errorPlacement

errorPlacement: function (error, element) {
    if (element.attr("type") == "checkbox") {
        error.insertAfter($(element).parents('div').prev($('.question')));
    } else {
        // something else if it's not a checkbox
    }
}

演示: http : //jsfiddle.net/sgsvtd6y/

也许您不需要条件,因为该技术应该适用于您的所有input类型。

errorPlacement: function (error, element) {
    error.insertAfter($(element).parents('div').prev($('.question'))); 
}

否则,如果您的 HTML 不同,那么您可以使用带有稍微修改的 DOM 遍历的条件。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM