Я оставляю список с элементами, которые получают класс «добавлен» при нажатии. Этот элемент передается в форму. Поэтому я сделал список флажков, которые имеют те же классы, что и «li» из списка.Переключить флажок, если элемент имеет класс
Я написал сценарий jQuery, который будет проверять, если щелкнуть «li» (hasClass), а затем соответствующий флажок должен иметь атрибут «checked». Но он работает неправильно. Не знаю, что я сделал неправильно ...
HTML:
<div class="container">
<div class="row row-centered konf-wrapper-1">
<div class="col-md-4 label-wrap">
<h1 class="header-label">Konzeption</h1>
<ul class="li-wrap">
<li class="added haken">Kommunikationsstrategie</li>
<li class="0 hide-me add-btn point">Zielgruppendefinition</li>
</ul>
</div>
<div class="col-md-4 label-wrap">
<h1 class="header-label">Kommunikationsmaßnahmen</h1>
<ul class="li-wrap">
<li class="1 hide-me add-btn point">Namensfindung & Logoentwicklung</li>
<li class="2 hide-me add-btn point">Exposé</li>
<li class="3 hide-me add-btn point">Textdesign</li>
<li class="4 hide-me add-btn point">Anzeigenkampagnen</li>
<li class="5 hide-me add-btn point">Außenwerbung</li>
<li class="6 hide-me add-btn point">Bautafelgestaltung</li>
</ul>
</div>
</div>
<div class="row row-centered konf-wrapper-2 label-wrap">
<div class="col-md-4 label-wrap">
<h1 class="header-label">Online-Marketing</h1>
<ul class="li-wrap">
<li class="8 hide-me add-btn point">Website</li>
<li class="9 hide-me add-btn point">Social Media</li>
<li class="10 hide-me add-btn point">Digitale Präsentation</li>
</ul>
</div>
<div class="col-md-4 label-wrap">
<h1 class="header-label">Virtuelle Welten</h1>
<ul class="li-wrap">
<li class="11 hide-me add-btn point">Innenvisualisierung</li>
<li class="11 hide-me add-btn point">Außenvisualisierung</li>
<li class="12 hide-me add-btn point">Virtuelle Begehung</li>
<li class="13 hide-me add-btn point">Augmented Reality</li>
</ul>
</div>
</div>
<button type="button" class="btn btn-primary added-btn" title="Zur Übersicht." id="gesamt-weiter" >Zum Formular</button>
</div>
Флажки:
<div class="">
<ul class="checker-wrap">
<li><input type="checkbox" id="0" value="Zielgruppendefinition" class="0 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="2" value="Exposé" class="2 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="3" value="Textdesign" class="3 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="4" value="Anzeigenkampagnen" class="4 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="5" value="Außenwerbung" class="5 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="6" value="Bautafelgestaltung" class="6 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="8" value="Website" class="8 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="9" value="Social Media" class="9 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="10" value="Digitale Präsentation" class="10 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="11" value="Visualisierungen" class="11 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="12" value="Virtuelle Begehung" class="12 checker" name="checkbox-group[]"></li>
<li><input type="checkbox" id="13" value="Augmented Reality" class="13 checker" name="checkbox-group[]"></li>
</ul>
</div>
JQuery:
var $check = $(".checker-wrap");
$(".add-btn").click(function() {
var $li = $(this).toggleClass("hide-me added haken");
var li_class = $(this).attr('class').split(" ");
var $wrap = $li.closest('.label-wrap');
// trigger checkbox for form
if (($li).hasClass("added")) {
$check.find('.'+li_class[0]).addAttr('checked');
} else {
$check.find('.'+li_class[0]).removeAttr('checked');
}
$wrap.find('h1').toggleClass('top-added', $wrap.find('.added').length > 0);
});
Так что вопрос в том, что делают Я должен изменить, что checkboxes запускаются, если li имеет добавленный класс, а если нет, то флажок должен быть снят флажком ...
сниппета работает, но не в моем коде. Не проблема, что флажки находятся в скрытом div? – Buntstiftmuffin
@Buntstiftmuffin Уверен, что вы включили jquery в свой код и написал все jquery в '$ (document) .ready (function())' –
Да. Я добавил строку $ check.find ('.' + Li_class [0]). Trigger ('click'); перед утверждением if. Теперь он работает ... Теперь он запускается, если щелкнут, и он проверяет, есть ли у этого класса «добавленный». Если нет, то он не установлен. Но почему-то это срабатывает дважды. Это вызовет проблемы? – Buntstiftmuffin