我有一组用于排序的链接,例如。类别,名称,日期,并有另一个组用于升序/降序。最初,在页面加载时,将不会选择这些内容,并且结果将不会以任何顺序排列。当做出选择时,我需要两个组都具有值,即。 sortby和sortorder。

例如,如果用户选择按“类别”排序,则以下功能将使用ASC作为默认排序方向。然后,我还需要能够通过在链接中添加“ selected”类来突出显示data-option-value =“ asc”链接。

有人可以协助吗?

        $('.sort a').click(function(e) {
            var $this = $(this);

            // Turn 'selected' class on/off
            if ($this.hasClass('selected'))
                return false;
            $this.parents('.sort-set').find('.selected').removeClass('selected');
            $this.addClass('selected');

            if($('.sortKey a.selected').attr('data-option-value')){
                key = $('.sortKey a.selected').attr('data-option-value');
            } else {
                 var key = 'date';
                 //.addClass('selected');  HOW TO DO THIS??
            }

            if($('.sortOrder a.selected').attr('data-option-value')){
                order = $('.sortOrder a.selected').attr('data-option-value');
            } else {
              var order = "asc";
              //.addClass('selected');  HOW TO DO THIS??
            }

            $container.isotope({sortBy: valBy, sortAscending: valAscending});

            return false;
          });

                    <div class="option-combo sort">
                        <ul class="sort sort-set clearfix sortKey">
                            <li><a href="#" data-option-value="name">Name</a></li>
                            <li><a href="#" data-option-value="category">Category</a></li>
                            <li><a href="#" data-option-value="date">Expiry Date</a></li>
                        </ul>
                    </div>
                    <div class="option-combo sort">
                        <ul class="sort sort-set clearfix sortOrder">
                            <li><a href="#" data-option-value="asc">Ascending</a></li>
                            <li><a href="#" data-option-value="desc">Descending</a></li>
                        </ul>
                    </div>

最佳答案

您可以在选择器中使用属性值:

$("element[attribute='value']").addClass('selected')


根据您的评论,您可能需要执行以下操作:

$("a[data-option-value='asc']", ".sortOrder").addClass('selected')

关于javascript - jQuery-如何将class()添加到与属性值匹配的元素,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21264259/

10-11 13:14