jquery过滤多个<ul> <li>查找值并调试</li> </ul>

时间:2013-11-07 20:59:22

标签: jquery dom filter

我是使用骨干视图并尝试调试的新手。我有填充表单验证 当出现错误时,如果我没有制作任何这些新元素,我只会将表单数据发送到后端,新的<ul><li>标记。我需要检查一下。我发现这是为了显示我的输入字段设置为:

$('input').each(function(){console.log($(this).attr('id')+'  '+$(this).val());});

我读过关于遍历DOM

的内容
var listItems = $( 'ul' );
var special = listItems.filter( 'li' );

这会在导航中找到第一个<ul> <li>

我需要帮助扫描DOM以获取这些新的<ul> <li>标签 我从chrome创建HTML并提供错误。谢谢!

<div class="nav-collapse collapse">
    <ul class="nav" id="navbutts">
        <li class="" id="homebutt"><a href="#">Home</a>
        </li>
        <li id="weddingbutt"><a href="#weddings">Weddings</a>
        </li>
        <li id="dancesbutt"><a href="#dances">Dances</a>
        </li>
        <li id="contactbutt"><a href="#contact">Contact</a>
        </li>
        <li id="registerbutt" class="active"><a href="#register">Register</a>
        </li>
        <li id="bookitbutt"><a href="#bookit">Book it</a>
        </li>
        <li class="dropdown">
            <a href="#" class="dropdown-toggle" data-toggle="dropdown">More<b class="caret"></b></a>
            <ul class="dropdown-menu">
                <li><a href="#owner">The Owner</a>
                </li>
                <li><a href="#equipment">Equipment</a>
                </li>
                <li><a href="#consulting">Event Consulting</a>
                </li>
                <li><a href="#testimonials">Testimonials</a>
                </li>
                <li><a href="#testimonialinks">Testimonials link</a>
                </li>
            </ul>
        </li>
    </ul>
</div>

<div class="control-group warning">
    <label class="control-label required" for="loginnameconf">Confirm Email</label>
    <div class="controls">
        <div class="input-prepend" data-role="acknowledge-input">
            <div data-role="acknowledgement" class="add-on" style="color: rgb(255, 0, 0);"><i class="icon-warning-sign"></i>
            </div>
            <input type="email" data-type="email" required="required" placeholder="Confirm email" maxlength="254" name="loginnameconf" id="loginnameconf" class="inputclass pageRequired input-xlarge" data-validation-match-match="loginname" data-validation-match-message="Emails must match"
            aria-invalid="true">
            <span class="loginnameconf_error label label-info hide"></span>
        </div>
        <div class="help-block">
            <ul role="alert">
                <li>Not a valid email address    // this was added to the DOM
                    <!-- data-validator-validemail-message to override -->
                </li>
                <li>Emails must match</li>    // this was added to the DOM
            </ul>
        </div>
    </div>
</div>

<div class="control-group warning">
    <label class="control-label required" for="password">Password</label>
    <div class="controls">
        <div class="input-prepend" data-role="acknowledge-input">
            <div data-role="acknowledgement" class="add-on" style="color: rgb(0, 255, 0);"><i class="icon-ok"></i>
            </div>
            <input type="password" required="required" placeholder="Password" minlength="6" maxlength="16" name="password" id="password" class="inputclass pageRequired input-medium" data-validation-minlength-message="6-16 characters required" data-validation-maxlength-message="6-16 characters required"
            aria-invalid="true">
        </div>
        <span class="password_error label label-info hide"></span>
        <div class="help-block">
            <ul role="alert">   // this was added to the DOM
                <li>6-16 characters required</li>
            </ul>
        </div>
    </div>  
</div>


// I can't seem to combine the filter and the .each to find the <ul><li> elements
   I added 

// shows names and values for form input text boxes
$('input').each(function(){console.log($(this).attr('id')+' '+$(this).val());}); 

var hasError = false; 

$('ul li').each(function(index){ 
    if( $(this).text().length !== 0 ){ 
        alert('Client side error found'); hasError = true; }
});

1 个答案:

答案 0 :(得分:0)

我无法找到这些验证库中的任何一个为我设置“验证成功”标志。因此,我需要确定是否存在新的

  • 标签

    I needed to scan for this:
    
         <div class="help-block">
            <ul role="alert">
                <li>Not a valid email address    // this was added to the DOM
    

    这样做

      $('div.help-block ul').each(function() {
         //alert('AHHHHHH!');
         hasError = true;
     }); // end each
    
     then later:
    
     if (hasError)
        { return false; }
      else
        {
        registermodel.save();
        return false;
            }