Angular 7.xx Переадресация только с routerLink
Я был назначен на этот рабочий проект с Angular. У нас есть несколько компонентов, которые имеют ссылку на нашу страницу условий и положений, но указанные страницы сильно вложены.
Увидеть ниже:
создать-order.component.html:
...
<div class="form-group">
<div class="custom-control custom-checkbox">
<input class="custom-control-input"
type="checkbox"
name="termsAccept"
id="termsAccept">
<label class="form-check-label w-100 custom-control-label pr-5"
for="termsAccept">
I agree to the <a routerLink="terms-and-conditions">Terms and Conditions</a>
</label>
</div>
<small class="text-info">Lorem ipsum do lor sit amet, consectetur adipiscing elit. </small>
</div>
...
создать-order.component.ts:
import { Component, OnInit } from '@angular/core';
import { PlatformCheckerTool } from '../../tools/platform-checker';
@Component({
selector: 'app-create-order',
templateUrl: './create-order.component.html',
styleUrls: ['./create-order.component.scss']
})
export class CreateOrderComponent implements OnInit {
start;
end;
constructor(private platformTool: PlatformCheckerTool) { }
ngOnInit() {
this.chekStoredOrderData();
}
chekStoredOrderData(): void {
if (this.platformTool.isBrowserCall()) {
const stored = sessionStorage.getItem('tmpOrderData');
if (stored) {
const storedData = JSON.parse(stored);
if (storedData) {
this.start = new Date(storedData['start']);
this.end = new Date(storedData['end']);
}
sessionStorage.removeItem('tmpOrderData');
}
}
}
}
заказ-routing.module.ts:
import { NgModule, Component } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { BasicLayout } from '../layouts';
import { OrderStepsLayoutComponent } from './layout/order-steps-layout.component';
import { CreatedOrderViewComponent } from './create/view/created-order-view.component';
import { CreateOrderLayoutComponent } from './create/layout/create-order-layout.component';
import { CreateOrderComponent } from './create/create-order.component';
import { AcceptOrderComponent } from './accept/accept-order.component';
import { RateFulfilledOrderComponent } from './rate-fulfilled/rate-fulfilled-order.component';
const routes: Routes = [
{
path: '', component: BasicLayout, children: [
{
path: '', component: CreateOrderLayoutComponent, children: [
{
path: 'clinic/:clinicId/services/:serviceId/order', component: CreateOrderComponent, pathMatch: 'full'
},
{ path: 'order/:orderId', component: CreatedOrderViewComponent, pathMatch: 'full' },
]
},
{
path: 'order/:orderId', component: OrderStepsLayoutComponent, children: [
{ path: 'accept', component: AcceptOrderComponent },
{ path: 'rate', component: RateFulfilledOrderComponent }
],
},
]
}
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class OrderRoutingModule { }
Моя проблема вращается вокруг путей, мне нужно использовать routerLink для перенаправления браузера, однако указанные ссылки вложены в:
[hostname]/clinic/:clinicId/services/:serviceId/order[terms&conditions route comes here]
[hostname]/order/:orderId/accept/[terms&conditions route comes here]
Что я пробовал: вставлять термины route и соответствующий компонент в качестве дочернего в массив маршрутов, но он выдает ошибку:
Error: Cannot match any routes. URL Segment: 'clinic/5c4f47065900472038f02a2d/services/0004/order/terms-and-conditions'
Said path is not existing, where I should redirect is:
[hostname]/terms-and-conditions#[fragment-name]
Я смотрел и читал много учебников, документации по маршрутизации, но они не подходят так. Как можно сделать такое "перенаправление" только с routerLink? перенаправление с помощью функции "щелкнуть" запрещено!
Заранее спасибо!
0 ответов
Мне удалось исправить проблему. Я не использовал routerLink вместо "/route-to-nav-to", я использовал "route-to-nav-to". И чтобы получить правильный фрагмент, мне просто нужно было добавить fragment="fragment-name" в навигацию к определенному фрагменту.