Здравствуйте, у меня есть приложение и модуль маршрутизации angularjs (AppRoutingModule), все работает хорошо, когда я вставляю <router-outlet></router-outlet> в app.component.html, но что, если я хочу показать некоторые страницы зарегистрированных пользователей, а не показать другие.

Я имею в виду это в моем app.component.ts

If (что-то) {показать страницу примера по умолчанию} else {показать страницу примера2}

Приложение - routing.module.ts

import { NgModule } from '@angular/core';
// Routing
import { RouterModule, Routes } from '@angular/router';
import { HomeComponent } from './home/home.component';
import { LoginComponent } from './login/login.component';
import { RegistrationComponent } from './registration/registration.component';

const appRoutes: Routes = [
  { path: '', component: HomeComponent },
  { path: 'login', component: LoginComponent },
  { path: 'registration', component: RegistrationComponent}
];

@NgModule({
  imports: [
    RouterModule.forRoot(
      appRoutes,

    )
  ],
  exports: [
    RouterModule
  ]
})
export class AppRoutingModule {}

App.module.ts

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';

import { AppComponent } from './app.component';
import { AlertModule } from 'ngx-bootstrap';

// Import the AF2 Module
import { AngularFireModule } from 'angularfire2';
import { AngularFireAuthModule } from 'angularfire2/auth';
import { AngularFireDatabaseModule } from 'angularfire2/database';
import { environment } from '../environments/environment';

import { AppRoutingModule } from './app-routing.module';
import { HomeComponent } from './home/home.component';
import { LoginComponent } from './login/login.component';
import { RegistrationComponent } from './registration/registration.component';

@NgModule({
  declarations: [
    AppComponent,
    RegistrationComponent,
    HomeComponent,
    LoginComponent
  ],
  imports: [
    BrowserModule,
    AlertModule.forRoot(),
    AngularFireModule.initializeApp(environment.firebase),
    AngularFireAuthModule,
    AngularFireDatabaseModule,
    AppRoutingModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

App.component.ts

import { Component } from '@angular/core';
import { AngularFireDatabase, FirebaseListObservable } from 'angularfire2/database';
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  title = 'app';
  items: FirebaseListObservable<any[]>;
  constructor(db: AngularFireDatabase) {
    this.items = db.list('/sms');
  }
}

App.component.html

<router-outlet></router-outlet>
1
Gocha 30 Авг 2017 в 12:48

3 ответа

Лучший ответ

Используйте this.router.navigate**(['/path']);

Здесь путь относится к пути компонента , который указан в app.module.ts .

Дополнительные ссылки можно найти на этой официальной угловой ссылке Документы.

1
Wilfredo P 16 Июл 2019 в 17:46

Чтобы перемещаться между страницами, вы можете добавить следующее в класс домашних компонентов:

import { Router } from '@angular/router';
....

constructor(private router: Router){}
...

А затем позвоните откуда-нибудь (как на (нажмите)):

if(condition){
    this.router.navigate(['/page1']);
}
else{
    this.router.navigate(['/page2']);
}

И добавьте это в маршруты:

.....
  { path: 'page1', component: Page2Component },
  { path: 'page2', component: Page1Component}
....

Либо добавьте это в домашний компонент HTML:

  <a class="home-app-link" routerLink="/page1">
    <h3>Page1</h3>
  </a>

  <a class="home-app-link" routerLink="/page2">
    <h3>Page2</h3>
  </a>
5
Vega 30 Авг 2017 в 10:02

В app.component.ts:

import { Router, ActivatedRoute, ParamMap } from '@angular/router';

Тогда в конструкторе:

if (3 < 2) {
  this.router.navigate(['/registration']);
} else {
  this.router.navigate(['/login']);
}
0
Moshe 30 Авг 2017 в 13:53