Angular 11 - 延迟加载路由问题

如何解决Angular 11 - 延迟加载路由问题

尝试使用 MEAN 堆栈创建 CRUD 操作。目前使用 Angular 11 cli,我创建了惰性模块。 惰性模块具有添加/编辑/列表组件。为了列出数据,我使用了 Angular 材料。问题 我在这里面临的是由于前端的以下错误而无法导航。

注意:这可能是重复的,但我已经看到了很少的 SO 解决方案,但不幸的是我无法解决这个问题超过 3 小时。

也许有些人有很好的眼光来指出我在这里所做的问题

app-routing.module.ts

const routes: Routes = [
  { path: 'home',component: HomeComponent },{ path: 'about',component: AboutComponent },{ path: 'students',loadChildren: () => import('./demo-app/demo-app.module').then(m => m.DemoCrudAppModule) },{ path: '',redirectTo: '/home',pathMatch: 'full' }
];

demo-crud-app-routing.module.ts

const routes: Routes = [
  
  { path: '',component: ListStudentsComponent,pathMatch: 'full' },{ path: 'add',component: AddNewStudentsComponent },{ path: 'view/:id',component: ViewStudentsDetailsComponent },{ path: 'edit/:id',component: EditStudentsComponent }
];

当我尝试单击 mat-table 数据以导航以查看学生详细信息时,出现控制台错误

错误错误:未捕获(承诺):错误:无法匹配任何路由。 URL 段:'view/607e79ee6d81777c6ee80919'

查看-student-details-component.html

<table mat-table [dataSource]="data" class="mat-elevation-z8 list-tbl" matSort matSortActive="firstName"
      matSortdisableClear matSortDirection="asc" *ngIf="data && data.length > 0">
      <!--- Note that these columns can be defined in any order.
                The actual rendered columns are set as a property on the row deFinition" -->
      <ng-container matColumnDef="_id">
        <th mat-header-cell *matHeaderCellDef>ID</th>
        <td mat-cell *matCellDef="let element">
          <a color="primary">{{ element._id }}

          </a>
        </td>
      </ng-container>
      <!-- Position Column -->
      <ng-container matColumnDef="firstName">
        <th mat-header-cell *matHeaderCellDef>Student Name</th>
        <td mat-cell *matCellDef="let element">{{ element.firstName }}</td>
      </ng-container>

      <!-- Name Column -->
      <ng-container matColumnDef="age">
        <th mat-header-cell *matHeaderCellDef>Age</th>
        <td mat-cell *matCellDef="let element">{{ element.age }}</td>
      </ng-container>

      <!-- Weight Column -->
      <ng-container matColumnDef="status">
        <th mat-header-cell *matHeaderCellDef>Status</th>
        <td mat-cell *matCellDef="let element">{{ element.status }}</td>
      </ng-container>

      <tr mat-header-row *matHeaderRowDef="displayColumns"></tr>
      <tr mat-row *matRowDef="let row; columns: displayColumns" [routerLink]="['/view/',row._id]"></tr>
    </table>

我的本地网址 - http://localhost:4200/students

提前致谢

解决方法

将您的路由器链接更改为

[routerLink]="['view',row._id]"

如果当前活动网址为 /students,则点击 tr 将导航至 http://localhost:4200/students/view/607e79ee6d81777c6ee80919

如果您在路径前添加 /,例如 ['/view/',row._id],那么无论当前的活动 URL 是什么,URL 都会导航到 http://localhost:4200/view/607e79ee6d81777c6ee80919

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?