2017-02-17 74 views
0

将接受任何JavaScript的解决方案,但是最好的答案可能使用angular2RouterLinkActive做工作ngFor

我试图动态地根据API调用来创建我的导航栏是一个。

问题是如果另一个li(child)处于活动状态,我希望父项li具有活动类。

下面的代码工作是什么,我希望它做的,但并不动态加载

<nav> 
       <ul> 
        <li> 
         <a (click)="togglePatientSideSearch()"><i class="fa fa-lg fa-fw fa-search"></i> <span class="menu-item-parent">Patient Search</span></a> 
        </li> 
        <li data-nav-target="1" [routerLinkActive]="['active']" [routerLinkActiveOptions]="{ exact: false }"> 
         <a (click)="toggleNavMenuParentSelected(1)" title="Dashboard"><i class="fa fa-lg fa-fw fa-home"></i> <span class="menu-item-parent">Payroll</span> 
         <b class="collapse-sign"> 
          <em class="fa fa-plus-square-o"></em> 
          </b> 
         </a> 
         <ul> 
          <li [routerLinkActive]="['active']"> 
           <a [routerLink]="['/payroll/summary']" title="Payroll Summary"><span class="menu-item-parent">Summary</span></a> 
          </li> 
          <li [routerLinkActive]="['active']"> 
           <a [routerLink]="['/payroll/daily']" title="Payroll Daily"><span class="menu-item-parent">Daily</span></a> 
          </li> 
         </ul> 
        </li> 
</nav> 

下面的代码是什么行不通,我试图解决!

<nav> 
      <ul *ngIf="navigationMenu"> 
       <li *ngFor="let nav of navigationMenu; let i = index;" [attr.data-nav-target]="nav.logo && !nav.children ? null : i" [attr.routerLinkActiveOptions]="nav.logo && !nav.children ? null : { exact: false }" [attr.routerLinkActive]="nav.logo && !nav.children ? null : ['active']" > 
        <a *ngIf="nav.logo && !nav.children" (click)="navigationClicked(nav)"><i class="{{nav.logo}}"></i> <span class="menu-item-parent">{{nav.name}}</span></a> 
        <a *ngIf="nav.logo && nav.children" (click)="toggleNavMenuParentSelected(i)" title="Dashboard"> 
         <i class="fa fa-lg fa-fw fa-home"></i> <span class="menu-item-parent">{{nav.name}}</span> 
         <b class="collapse-sign"> 
          <em class="fa fa-plus-square-o"></em> 
         </b> 
        </a> 
        <ul *ngIf="nav.children"> 
         <li [routerLinkActive]="['active']" *ngFor="let child of nav.children;"> 
          <a [routerLink]="['/home']" title="Home"><span class="menu-item-parent">{{child.name}}</span></a> 
         </li> 
        </ul> 
       </li> 
      </ul> 
     </nav> 

我加载在一个对象,同时呼吁navigationMenu整个导航栏。 下面是我想让它看起来像什么样的动态加载!(忽略不同的名字)

enter image description here

enter image description here

+0

或许这是与这个已知的错误:https://github.com/angular/angular/issues/14227 – mxii

+0

我想这个问题是在新的角度,更新软件包最新,还尝试删除[]标记,如'routerLinkActive =“active”'和'routerLink =“/ user”' –

回答