Angular2 路由问题修复详解

网络编程 2021-07-04 19:20www.168986.cn编程入门
这篇文章主要介绍了Angular2 路由问题修复详解的相关资料,并建了一个测试工程,把详细的过程分享给大家,需要的朋友可以参考下

Angular2 提供了比angular1 更为强大的路由功能,在具体使用路由过程中,可是出现了很多路由不按照预想的方式执行的问题。为了说明今天的问题,我特地新建了一个测试工程。欢迎交流。

介绍一下测试代码的组织结构,

其中包含两个组件button、aordion。这个例子采用的是ng2-bootstrap.

我展示一下路由配置

/
  Created by guozhiqi on 2017/2/24.
 /
import {Route,Routes}from '@angular/router';
import {AppComponent}from './app.ponent';
import {LayoutComponent}from './layout/layout.ponent';

export const routes:Routes=[
 {
  path:'',
  redirectTo:'button',
  pathMatch:'full'
 },
 {
  path:'',
  ponent:LayoutComponent,
  children:[
   {
    path:'button',
    loadChildren:'./Button/Button-guo.module#ButtonGuoModule'
   },
   {
    path:'aordion',
    loadChildren:'./aordionguo/aordion-guo.module#AordionGuoModule'
   }
  ]
 },
 {
  path:'',
  redirectTo:'button',
 }
];

这段路由中我定义了默认路由,会跳转到button,我采用最新的angular-cli,并没有进行跳转,并且默认路由并没有使用layoutponent组件,这是最大的问题,因为layoutponent组件是整个页面的样式文件。

目前的结果什么呢?

我展示一下appmodule.ts代码

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { HttpModule } from '@angular/http';
import {ButtonGuoModule}from './button/button-guo.module';
import { AppComponent } from './app.ponent';
import {ButtonsModule}from 'ng2-bootstrap/buttons';
import {routes}from './app.routing';
import {RouterModule}from '@angular/router';
import {CommonModule}from '@angular/mon';
import {AordionGuoModule}from './aordionGuo/aordion-guo.module';
import {LayoutComponent}from './layout/layout.ponent';
@NgModule({
 declarations: [
  AppComponent,LayoutComponent
 ],
 imports: [RouterModule.forRoot(routes),AordionGuoModule,
  BrowserModule,RouterModule,CommonModule,
  FormsModule,ButtonGuoModule,
  HttpModule
 ],
 providers: [],
 bootstrap: [AppComponent]
})
export class AppModule { }

请注意appmodule.ts中我标红的引入module,如果我将aordionmodule放在buttonmodule前面,那么显示的就是aordionmodule的内容,反之显示的就是buttonmodule的内容。

执行结果

1.aordionmodule在buttonmodule前面

2.buttonmodule在aordionmodule前面

请注意,更改了顺序以后,务必重新编译,重新执行 ng serve命令。

会什么会出现这个问题?欢迎大家交流。下篇我会专门解释这个问题的答案

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by