gpt4 book ai didi

angularjs - Angular JS : "active" class on menu items created by a controller

转载 作者:行者123 更新时间:2023-12-04 07:39:36 25 4
gpt4 key购买 nike

我正在使用 JSON 服务来列出菜单项(链接)。在导航不同的路线/页面时,我希望将“事件”类添加到当前处于事件状态的链接(即用户所在的页面)。

我使用这个 jsfiddle 作为起点: http://jsfiddle.net/p3ZMR/4/

我还在 stackoverflow 上找到了几个答案,但所有答案都类似于上面的解决方案。

但是,如果链接是通过 ng-repeat 生成的,则该解决方案不起作用:

  <ul class="main-menu">
<li ng-repeat="page in pages">
<a href="/#/{{page.id}}" active-link="active">{{page.name}}</a>
</li>
</ul>

似乎在 Controller 添加链接之前调用了该指令。

有没有办法解决这个问题?

最佳答案

用于重复链接的 HTML

<div ng-app="link">
<div data-ng-controller="myController">
<a href="#/{{ link.url }}" data-ng-repeat="link in links" data-ng-class="(link.url == location.path() && 'active')">
{{ link.name }}
</a>
</div>
</div>

Javascript
angular.module('link', [])

function myController($scope, $location){
$scope.location = $location;
$scope.links = [
{ url: "one", name: "One"},
{ url: "two", name: "Two"},
{ url: "", name: "Three"}
];
}

这将生成链接一/二/三,其中三个以红色突出显示。这是一个 jsfiddle: http://jsfiddle.net/4mFYy/1/

关于angularjs - Angular JS : "active" class on menu items created by a controller,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16573396/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com