所有关于这个角度错误的文章都是为了确保一个人注入了这样的“路由器”:
构造器(路由器:路由器.
我已经做过了。
我不知道还能做什么。在我开始对线路进行故障排除之前,我必须修复这个问题。
我的目标:允许用户导航到子路径。允许用户在单击时关闭当前路由。
所以现在的地址是:https://localhost:4200/layout/usermanagement/(newuser:newuser/(newuserinput:newuserinput))
单击后,我将被路由到:https://localhost:4200/layout/usermanagement/(newuser:newuser/(newuserorginfo:newuserorginfo))
另外,单击另一个按钮后,我将被路由到:https://localhost:4200/layout/usermanagement/(newuser:newuser))
这是我的组件、模块和模板。
组件新用户输入组件
import { Component, OnInit } from '@angular/core';
import { slideToRight } from '../../../../router.animations';
import { Router, ActivatedRoute, UrlSegment } from '@angular/router';
@Component({
selector: 'app-new-user-input',
templateUrl: './new-user-input.component.html',
styleUrls: ['./new-user-input.component.css'],
animations: [slideToRight()]
})
export class NewUserInputComponent implements OnInit {
router: Router;
constructor(router: Router, r: ActivatedRoute) {
r.url.subscribe((s: UrlSegment[]) => {
console.log("url", s); //https://vsavkin.com/angular-router-understanding-router-state-7b5b95a12eab
});
}
ngOnInit() {
}
displaySibling() {
console.log(this.router);
this.router.navigate(['../', { outlets: { newuserorginfo: ['newuserorginfo'] } }])
}
closeBlade() {
this.router.navigate([{ outlets: { newuserinput: null } }]);
}
}模块用户管理.module.ts
import { HttpModule, JsonpModule } from '@angular/http';
import { BrowserModule } from '@angular/platform-browser';
// import 'rxjs/add/operator/map';
import { NgModule, Type, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { CommonModule } from '@angular/common';
import { GridAllModule } from '@syncfusion/ej2-ng-grids';
import { HttpClientModule } from '@angular/common/http';
import {
GridModule, ToolbarService, EditService, SortService, GroupService, FilterService, PageService,
ContextMenuItem, PdfExportService, ExcelExportService, ContextMenuService, ResizeService,
DataSourceChangedEventArgs, DataStateChangeEventArgs
} from '@syncfusion/ej2-ng-grids';
import { UserManagementComponent } from './user-management.component';
import { PageHeaderModule } from './../../shared/page-header/page-header.module';
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
// import { NewUserComponent } from './new-user/new-user.component';
// import { PendingUserComponent } from './pending-user/pending-user.component';
// import { ProcessUserComponent } from './process-user/process-user.component';
// import { NewUserInputComponent } from './new-user/new-user-input/new-user-input.component';
import { RouterModule } from '@angular/router';
import { NewUserOrgInfoComponent } from './new-user/new-user-org-info/new-user-org-info.component';
import { NewUserSupervisorInfoComponent } from './new-user/new-user-supervisor-info/new-user-supervisor-info.component';
import { NewUserSecurityInfoComponent } from './new-user/new-user-security-info/new-user-security-info.component'; //??????????
@NgModule({
imports: [
CommonModule,
PageHeaderModule,
GridModule,
RouterModule,
NgbModule
],
declarations: [UserManagementComponent, NewUserOrgInfoComponent, NewUserSupervisorInfoComponent, NewUserSecurityInfoComponent],
providers: [EditService, ToolbarService, SortService, GroupService, FilterService, PageService,
ContextMenuService, PageService, ResizeService, PdfExportService, ExcelExportService]
})
export class UserManagementModule {
}新模板-用户-input.Component.html
<div class="blade" [@routerTransition]>
<div class="blade-header">
<h3>User Information</h3>
<div class="window-functions">
<i class="fa fa-window-minimize"></i>
<i class="fa fa-window-restore"></i>
<i class="fa fa-window-maximize"></i>
<!-- <a routerLink='/layout/usermanagement/(newuser:newuser)' routerLinkActive='router-link-active'> -->
<i (click)='closeBlade()' class="fa fa-window-close"></i>
<!-- </a> -->
</div>
</div>
<form action="submit">
<!-- <label for="firstname">First Name:</label> -->
First name:
<br>
<input type="text" name="firstname" value="Richard">
<br> Last name:
<br>
<input type="text" name="lastname" value="Dawkins">
<br> Cell phone:
<br>
<input type="tel" name="cellphone" value="(585) 271-8888">
<br> Office phone:
<br>
<input type="tel" name="officephone" value="(585) 271-8887">
<br> Fax:
<br>
<input type="tel" name="fax" value="(585) 271-8886">
<br> City:
<br>
<input type="text" name="city" value="City">
<br> State:
<br>
<input type="text" name="state" value="New York">
<br> Requester title:
<br>
<br>
<!-- <input type="submit" value="Next" disabled="true"> -->
<input class="next-button" type="submit" value="Next" (click)="displaySibling()">
<!-- <input type="submit" value="Next" [routerLink]="[{ outlets: { newuserorginfo: ['newuserorginfo '] } } ]" routerLinkActive='active '> -->
</form>
</div>
<router-outlet></router-outlet>
<router-outlet name="newuserorginfo"></router-outlet>发布于 2018-05-23 18:20:13
发生此错误是因为router不是组件类的成员。在构造函数中注入服务时,指定访问级别(private、protected或public)将使router成为类的属性并修复此问题:
constructor(private router: Router, ...)发布于 2021-06-29 06:32:23
我遇到的问题是注销方法的句柄错误。让我告诉你:
public logout(): Observable<any> {
return this.http
.get('logout_url')
.pipe(
map(a => this.mapLogoutResult(a)),
catchError(this.handleError)
);
}
handleError:
public handleError(err) {
localStorage.setItem('isAuthenticated', 'false');
if (this.heartbeatOn) {
this.heartBeat.next(false);
}
this.router.navigate(['/login']);
throwError(err);
return of({ failure: err });
}
在这里我不断地收到:
Cannot read property 'navigate' of undefined我通过改变handleError在catchError中的调用方式来解决这个问题。
catchError(err => this.handleError(err))
catchError中的箭头函数定义了作用域,因此它看起来像没有箭头的函数,函数没有适当的输入。
发布于 2022-10-08 16:31:38
在构造函数中没有注入路由。
试试这个:
constructor(private route:Router){}https://stackoverflow.com/questions/50489080
复制相似问题