У меня есть выпадающая панель навигации с различными ссылками маршрутизатора для каждой опции.
Когда пользователь выполняет поиск, я хочу, чтобы тип поиска и значение фильтра поиска запоминались, и чтобы предыдущие значения отображались, когда пользователи снова переходят к параметру поиска. Я использую службу, чтобы тип поиска и значение фильтра поиска были доступны в приложении, но я не могу заставить его работать. Тип поиска и значение фильтра поиска инициализируются, когда я возвращаюсь к поиску.
Пожалуйста, дайте мне знать, что мне не хватает ...
app.component.ts:
-----------------
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'Proto Tracking';
}
app.module.ts:
--------------
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { HttpClientModule } from '@angular/common/http';
import { FormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
import { AppRoutingModule } from './app-routing.module';
import { UserSearchComponent } from './components/user-search/user-search.component';
import { UserUpdateComponent } from './components/user-update/user-update.component';
import { UsersService } from './services/users.service';
@NgModule({
declarations: [
AppComponent,
UserSearchComponent,
UserUpdateComponent
],
imports: [
BrowserModule,
AppRoutingModule,
HttpClientModule,
FormsModule
],
providers: [ UsersService ],
bootstrap: [AppComponent]
})
export class AppModule { }
user-search.component.ts:
-------------------------
import { Component, OnInit, Injectable, Directive, OnDestroy } from '@angular/core';
// import User model/interface
import { User } from '../../../app/models/User';
import { UsersService } from '../../../app/services/users.service';
@Component({
selector: 'app-user-search',
templateUrl: './user-search.component.html',
styleUrls: ['./user-search.component.css']
})
@Injectable()
export class UserSearchComponent implements OnInit {
users: User[];
searchType: String; searchVal: String;
constructor(private usersService: UsersService) {
}
ngOnInit() {
alert("Search component.OnInit");
alert("Service:" + this.usersService.getSearchType());
alert("local:" + this.searchType);
this.searchType = this.usersService.getSearchType();
this.searchVal = this.usersService.getSearchVal();
}
getUsers (searchType: String, searchVal: String) {
this.usersService.getUsers(this.searchType, this.searchVal).subscribe(users => this.users = users);
//this.usersService.setSearchType(this.searchType);
//this.usersService.setSearchVal(this.searchVal);
}
ngOnDestroy() {
alert ("search destroy");
this.usersService.setSearchType(this.searchType);
this.usersService.setSearchVal(this.searchVal);
alert(this.usersService.getSearchType());
}
}
app-routing.module.ts:
----------------------
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import {UserSearchComponent} from "../app/components/user-search/user-search.component";
import {UserUpdateComponent} from "../app/components/user-update/user-update.component";
const routes: Routes = [
{path: 'searchUser', component: UserSearchComponent},
{path: 'updateUser', component: UserUpdateComponent}
];
@NgModule({
imports: [ RouterModule.forRoot(routes) ],
exports: [RouterModule]
})
export class AppRoutingModule {
}
app.component.html:
-------------------
<div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
<a class="dropdown-item" href="#">Add user</a>
<a class="dropdown-item" href="/searchUser">Search user</a>
<a class="dropdown-item" href="/updateUser">Update user</a>
</div>
users.service.ts:
-----------------
import { Injectable } from '@angular/core';
import { User } from '../../app/models/User';
import { Observable } from 'rxjs/Observable';
import { of } from 'rxjs/observable/of';
import { HttpHeaders, HttpClient } from '@angular/common/http';
import { catchError, map, tap } from 'rxjs/operators';
const httpOptions = {
headers: new HttpHeaders({ 'Content-Type': 'application/json' }
)
};
@Injectable()
export class UsersService {
searchType: String;
searchVal: String;
loginUser: {};
updUser: User;
private userSearchUrl = 'http://localhost/ProtoServices/rest/userSearch';
constructor(private http: HttpClient) {
alert("Service.Constructor:" + this.searchType);;
}
private handleError<T>(operation = 'operation', result?: T) {
return (error: any): Observable<T> => {
console.error(error); // log to console instead
return of(result as T);
};
}
setSearchType(value: String) {
this.searchType = value;
}
getSearchType(): String {
return this.searchType;
}
setSearchVal(value: String) {
this.searchVal = value;
}
getSearchVal(): String {
return this.searchVal;
}
getUsers(searchType: String, searchVal: String): Observable<User[]> {
this.searchType = searchType;
this.searchVal = searchVal;
alert("Service.getUsers:" + this.searchType);
return this.http.post<User[]>(this.userSearchUrl, { 'searchType': searchType, 'searchVal': searchVal }, httpOptions).pipe(
catchError(this.handleError('getUsers', []))
);
}
}