【问题标题】:add CSS element using an angular directive使用角度指令添加 CSS 元素
【发布时间】:2015-10-26 18:41:00
【问题描述】:

我正在使用 angular 和 ng-repeat 来填充研究列表。此列表是动态的,因此您可以切换到每个元素的子元素。所以基本上我有一个手风琴风格的切换列表,可以在每个列表项上深入三层。我有一个 jQuery 问题,我认为应该用一些角度指令或其他东西来解决。基本上,我有一个箭头(字形图标),它应该向上或向下切换,具体取决于您查看的是此列表中的子元素还是父元素。我有这个使用纯 jQuery 只是从每个列表项中添加和删除一个 css 类。但是,它只适用于列表中的第一项,因为 ng-repeat 创建了多个 id,但 jQuery 只适用于具有该 id 标记的第一个元素。

这是页面中的 HTML。

<!-- User Studies List -->
<div ng-controller="StudiesController" id="before">
    <h3 class="center"> User Studies </h3>
    <div ng-repeat="study in studies" arrow>
        <div class="panel-group" style="margin-bottom:0">
            <div class="panel panel-default">
                <div class="panel-heading" data-toggle="collapse" href="#collapse{{$index}}">
                    <h3 class="panel-title">{{ study.study }} <span class="glyphicon glyphicon-menu-down pull-right"></span></h3>
                    <p></p>
                </div>
                <div id="collapse{{$index}}" class="panel-collapse collapse">
                    <ul class="list-group">
                        <li class="list-group-item" data-toggle="collapse" href="#collapse{{study.id}}" style="margin-left:1%" id="sampleID{{$index}}">
                            <i>Sample: </i>{{ study.sample }}
                            <span id="glyph-switch" class="glyphicon glyphicon-menu-down pull-right"></span>
                            <span id="glyph-up" class="glyphicon glyphicon-menu-up pull-right"></span>
                        </li>
                        <div id="collapse{{study.id}}" class="panel-collapse collapse">
                            <ul class="list-group">
                                <li class="list-group-item" style="margin-left:3%"><i>Fastq: </i>{{ study.fastq }}
                                    <div class="dropdown center pull-right">
                                        <button class="btn-xs btn-default hvr-shadow" id="dLabel" type="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
                                            Action <span class="caret"></span>
                                        </button>
                                        <ul class="dropdown-menu" aria-labelledby="dLabel">
                                            <li id="list-item" data-toggle="modal" data-target="#more-metadata-modal" ng-click="showMore(study)">More Data</li>
                                            <li id="list-item" data-toggle="modal" data-target="#edit-metadata-modal" ng-click="showMore(study)">Edit</li>
                                            <li id="list-item" data-toggle="modal" data-target="#delete-metadata-modal" ng-click="showMore(study)">Delete</li>
                                        </ul>
                                    </div>
                                </li>
                            </ul>
                        </div>
                    </ul>
                </div>
            </div>
        </div>
    </div>
</div>

这是Javascript

var count = 1;
$(document).on("click", "li[id*='sampleID']", function() {
    console.log("clicked");
    if(count > 0) {
        $('#glyph-switch').css('visibility','hidden');
        $('#glyph-up').css('visibility', 'visible');
        count -= 1;
        console.log("count", count);
    } else {
        $('#glyph-switch').css('visibility','visible');
        $('#glyph-up').css('visibility', 'hidden');
        count += 1;
        console.log("count",count);
    }
});

【问题讨论】:

    标签: javascript jquery html css angularjs


    【解决方案1】:

    我只会使用角度代码(根本没有 jQuery)。

    由于您已经有一个研究对象,只需处理 onClick="showGlyph($index)" 传递索引,然后在代码中设置向上/向下箭头 $scope.GlyphUp = !$scope.GlyphUp 的状态。

    在模板文件中有向上/向下箭头对象绑定ng-show="GlyphUp"

    【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-11-19
    • 2014-05-27
    • 1970-01-01
    • 1970-01-01
    • 2016-04-13
    • 1970-01-01
    • 2023-03-09
    • 2021-10-06
    相关资源
    最近更新 更多