Angular 5.2: сохранение данных по маршрутам с использованием сервиса - PullRequest
0 голосов
/ 02 мая 2018

У меня есть выпадающая панель навигации с различными ссылками маршрутизатора для каждой опции. Когда пользователь выполняет поиск, я хочу, чтобы тип поиска и значение фильтра поиска запоминались, и чтобы предыдущие значения отображались, когда пользователи снова переходят к параметру поиска. Я использую службу, чтобы тип поиска и значение фильтра поиска были доступны в приложении, но я не могу заставить его работать. Тип поиска и значение фильтра поиска инициализируются, когда я возвращаюсь к поиску. Пожалуйста, дайте мне знать, что мне не хватает ...

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', []))
    );
  }
}

1 Ответ

0 голосов
/ 07 мая 2018

После того, как я изменил href на [routerLink '] в app.component.html, проблема была решена.

Спасибо.

...