在Angular中,当用户访问不存在的路径时,通常会显示一个404组件。然而,有时候我们希望在用户访问其他重定向路径的一些部分时也显示404组件。下面是一个解决方法的代码示例:
首先,在你的路由配置文件中,定义404路径和其他重定向路径的一些部分。例如:
const routes: Routes = [
// 其他重定向路径的一些部分
{ path: 'other-path', redirectTo: '/some-component' },
{ path: 'other-path/some-part', redirectTo: '/some-component' },
// 404路径
{ path: '404', component: NotFoundComponent },
// 默认路径
{ path: '**', redirectTo: '/404' }
];
然后,在你的404组件中,添加一些逻辑以检查当前路径是否匹配其他重定向路径的一些部分。如果匹配,则显示404组件。例如:
import { Component, OnInit } from '@angular/core';
import { ActivatedRoute } from '@angular/router';
@Component({
selector: 'app-not-found',
template: `
404 - Not Found
The requested page could not be found.
`
})
export class NotFoundComponent implements OnInit {
isMatchingRedirectPath: boolean = false;
constructor(private route: ActivatedRoute) {}
ngOnInit() {
this.route.url.subscribe(urlSegments => {
const url = urlSegments.map(segment => segment.path).join('/');
// 检查是否匹配其他重定向路径的一些部分
if (
url.startsWith('other-path') ||
url.startsWith('other-path/some-part')
) {
this.isMatchingRedirectPath = true;
}
});
}
}
这样,当用户访问其他重定向路径的一些部分时,会显示404组件。请根据你的实际需求修改路径和组件的名称。
上一篇:Angular 8 - 404 Not Found 实例化 http://localhost:4200/rxjs/operators
下一篇:Angular 8 - @ViewChild在父组件上返回undefined(没有嵌套的ngIf并在ngAfterViewInit中调用)