Я имею вопрос пытается получить ниспадающее меню для переключения к следующему варианту, который имеет данные завершенной = ложныйСледующая выбрать вариант, соответствующий фильтр
<select id="selectionChamp">
<optgroup label="1">
<option data-completed=true selected>Text 1</option>
</optgroup>
<optgroup label="2">
<option data-completed=true>Text 2</option>
</optgroup>
<optgroup label="3">
<option data-completed=true>Text 3</option>
</optgroup>
<optgroup label="45">
<option data-completed=false>Text 4</option>
<option data-completed=false>Text 5</option>
</optgroup>
</select>
<input type="button" id="fieldNext" value="Next">
Javascript:
$("#fieldNext").click(function() {
var $selected = $("option:selected");
var filter = "[data-completed!=true]";
$selected.attr("data-completed", true).prop("selected", false);
var $next = $selected.next("option"+ filter);
if ($next.length === 0) {
$next = $selected.parent("optgroup").next("optgroup:has(option"+ filter+")").find("option"+ filter+":first");
}
$next.prop("selected", true);
});
См: http://jsfiddle.net/w9kcd/105/
Я получил это работает, когда filter = "";
, но не тогда, когда filter = "[data-completed!=true]";
Он должен начинаться с 1 и перейти к 4, затем 5, пропуская 2 и 3.