2016-09-12 2 views
-2

Я хочу найти ближайший span с классом error_span. Как я могу это сделать с помощью jQuery?Найти ближайший пролет с определенным классом внутри div

<div class="form-group row"> 
    <div class="col-sm-4"> 
     <label for="reimburse_price" class="control label">Amount</label> 
    </div> 
    <div class="col-sm-8"> 
     <div> 
      <input type="text" name="reimburse_price" min="1" placeholder='0.00' class="form-control numberOnly" id="reimburse_price" required>   
     </div> 
     <div> 
      <span class="small text-danger error_span"></span>  
     </div> 
    </div> 
</div> 

Мой Javascript здесь

$("#reimburse_price").blur(function(){ 
    checkNumInput("#reimburse_price"); 
}); 

Моя функция JQuery здесь

function checkNumInput(id){ 
    if ($(id).val() == "") { 
     $(id)[0].setCustomValidity('Please fill out this field'); 
     $(id).closest("span .error_span").text("Please fill out this field").removeClass("hidden").addClass("text-danger"); 
    } 
} 
+1

Ближайший источник или ребенок? И ближайший относительно какого элемента? –

+0

Ближайшие по отношению к? – Joseph

+0

Относительно какого элемента? –

ответ

4

Проблема с текущим кодом является то, что closest() смотрит на родительских элементов, тем не менее span вы хотите find является дочерним по отношению к родительскому брату до input.

Чтобы решить вашу проблему, перейдите к общему родительскому объекту как input, так и span и используйте find() оттуда. Попробуйте следующее:

$("#reimburse_price").blur(function() { 
    checkNumInput('#' + this.id); 
}); 

function checkNumInput(id) { 
    var $input = $(id); 
    if ($input.val() == "") { 
     $input.get(0).setCustomValidity('Please fill out this field'); 
     $input.closest('.form-group').find('.error_span').text("Please fill out this field").toggleClass("hidden text-danger"); 
    } 
} 
+0

Спасибо, он сработал отлично. Последний последний вопрос будет работать, если в div есть класс с классом form-group? – healer

+0

Если у вас более одного элемента с классом '.form-group', он все равно будет работать, но он установит текст и классы для обоих этих элементов. –

+0

Является ли моя процедура прекрасной? В моей функции, где я передаю идентификатор элемента, я найду только ближайший класс группы .form? – healer