У меня проблема с кодом:
//routes
const routes: Routes = [
{path: '', component: HomeComponent},
{path: 'users', component: UsersComponent,
children: [
{path: ':userId', component: UserComponent},
{path: ':userId/edit', component: UserEditComponent}
]
},
{path: 'jobs', component: JobsComponent,
children:[
{path: ':mainNumber', component: JobComponent},
{path: ':mainNumber/edit', component: JobEditComponent}
]
}
//jobs component ts:
import { Component, OnInit, Input } from '@angular/core';
import { JobService } from '../job.service';
import { Job } from '../model/job.model';
import { UsersService } from '../users/users.service';
import { Router, ActivatedRoute, Params } from '@angular/router';
@Component({
selector: 'app-jobs',
templateUrl: './jobs.component.html',
styleUrls: ['./jobs.component.css']
})
export class JobsComponent implements OnInit {
jobs: Job[];
constructor(private jobService: JobService, private userService: UsersService,
private router: Router, private activatedRoute: ActivatedRoute) {}
ngOnInit() {
this.jobs = this.jobService.getJobs();
this.activatedRoute.queryParams.subscribe((queryParams: Params)=>{
if(queryParams['userId']){
let userId = +queryParams['userId'];
this.jobs = this.jobService.getJobByUser(userId);
}
});
}
onClick(maninNumber: number){
this.router.navigate([maninNumber], {relativeTo: this.activatedRoute});
}
}
//jobs component html:
<div class="container">
<div class="row">
<div class="col-md-7">
<table class="table table-bordered">
<thead>
<tr>
<th scope="col">Lp.</th>
<th scope="col">L. dz.</th>
<th scope="col">Rodzaj sprawy</th>
<th scope="col">Osoba prowadząca</th>
<th scope="col">Opis sprawy</th>
<th scope="col">Wnioskodawca</th>
<th scope="col">Status</th>
</tr>
</thead>
<tbody *ngFor="let job of jobs; let i = index;">
<tr clickOnRowDirective (click)="onClick(job.mainNumber)">
<th scope="row">{{ i + 1 }}</th>
<td>{{ job.caseNr }}</td>
<td>{{ job.caseType }}</td>
<td>{{ job.fullName }}</td>
<td>{{ job.what }}</td>
<td>{{ job.who }}</td>
<td>{{ job.status }}</td>
</tr>
</tbody>
</table>
</div>
<div class="col-md-5">
<router-outlet></router-outlet>
</div>
</div>
</div>
//app component
<div class="container">
<h3 class="p-3">jaobAssist</h3>
<ul class="nav nav-tabs justify-content-left">
<li class="nav-item">
<a class="nav-link"
[routerLink]="['/']"
routerLinkActive="active"
[routerLinkActiveOptions]="{exact:true}">
Menu</a>
</li>
<li class="nav justify-content-center">
<a class="nav-link"
[routerLink]="['/users']"
routerLinkActive="active">
Użytkownicy</a>
</li>
<li class="nav justify-content-center">
<a class="nav-link"
[routerLink]="['/jobs']"
routerLinkActive="active">
Sprawy</a>
</li>
</ul>
<router-outlet></router-outlet>
</div>
Предположения проекта:
Компонент задания отображает все объекты задания в таблице.
Объекты заданий можно фильтровать с помощью параметра userId. В этом случае я получаю все задания указанного пользователя, отраженные в JobsComponent (путь: / jobs? UserId = 1). Можно щелкнуть по одному объекту задания (строка в таблице), что переключает навигацию на страницу, например, / jobs / 1481 (один JobComponent отображается в JobComponent html с помощью функции маршрутизатора-выхода)
Здесьвопрос.
Когда я нахожусь на одном из дочерних путей, указанных выше (например, / jobs? userId = 1 / jobs / 1788), и я хочу вернуться к / jobs (нажав nav-tabs: [routerLink] = "['/ jobs']"), который при вводе отображает все объекты заданий, происходит перенаправление на / jobs, но я получил то же представление о JobsComponent, содержащем отфильтрованные объекты.
Как добитьсяфункциональность, чтобы перезагрузить все объекты заданий и воспроизвести его?
Заранее спасибо