分享
为什么使用路由
- 将应用程序划分为多个分区
- 维护应用程序的状态
- 基于某些规则保护应用分区
我觉得我已经会了angular的基本套路了,导入+配置,所以路由也是一样。
整个路由的API
interface Route {
path?: string
pathMatch?: string
matcher?: UrlMatcher
component?: Type<any>
redirectTo?: string
outlet?: string
canActivate?: any[]
canActivateChild?: any[]
canDeactivate?: any[]
canLoad?: any[]
data?: Data
resolve?: ResolveData
children?: Routes
loadChildren?: LoadChildren
runGuardsAndResolvers?: RunGuardsAndResolvers
}
导入
import { RouterModule, Routes } from '@angular/router';
配置
const routes: Routes = [
{ path: '', redirectTo: 'home', pathMatch: 'full' },
{ path: 'home', component: HomeComponent },
{ path: 'about', component: AboutComponent },
{ path: 'contact', component: ContactComponent },
{ path: 'contactus', redirectTo: 'contact' },
];
红色区域:
并没有定义contactus的绑定组件,所以这里的意思是当地址为contactus时,自动重定向(跳转)到contact的页面,此页面已经与ContactComponent进行绑定。
黄色区域:
与红色区域知识点相同,不同点在pathMatch,默认为prefix。
| pathMatch?: string | |
|---|---|
| prefix | 默认情况下,路由器从左方检查URL元素以查看URL是否与给定路径匹配,并在匹配时停止。例如,“ / team / 11 / user”与“ team /:id”匹配。 |
| full | 路径匹配策略“完整”与整个URL匹配。重定向空路径路由时,执行此操作很重要。否则,因为空路径是任何URL的前缀,所以路由器即使在导航到重定向目标时也将应用重定向,从而造成无限循环。 |
安装路由
更改NgModule:
- 导入RouterModule
- 在NgModule中的imports数组里使用RouterModule.forRoot(routes)来安装路由配置
关于RouterOutlet
前提也是导入(RouterModule),别忘了导入+配置的模式。
router-outlet元素标示了各个路由组件的内容应该在哪里被渲染。
router-outlet在整个导航目录的正下方,当访问/home时候,这里便是HomeComponent被渲染的地方,相同在访问/about,/contact同理。打个比方,点到谁,谁上场,router-outlet提供一个出口,场地的作用。
关于routerLink
还是刚刚那张图,routerLink可以在不重载页面的情况下链接路由。
相对于 <a href="/#/home">Home</a> 之前直接用href超链接形式的优化。
<base href="/">
在html中的位置:
如果一个路由的路径为/home ,base元素的声明是href=“mine”,那么程序将使用/mine/#/home为实际路径。
等同方法:
@NgModule({
declarations: [ RoutesDemoApp ],
imports: [
BrowserModule,
RouterModule.forRoot(routes) // <-- routes
],
bootstrap: [ RoutesDemoApp ],
providers: [
{ provide: LocationStrategy, useClass: HashLocationStrategy },
{ provide: APP\_BASE\_HREF, useValue: '/' } // <--- this right here
]
})
将{ provide: APP_BASE_HREF, useValue: ‘/’ }放到providers中,等同于在HTML中使用
。
创建组件
路由引入配置安装完毕了,得一路由一组件匹配一下。
导入组件
不多说了,import就完事了
路由策略
基础学习:
前端最基础的就是 HTML , CSS 和 JavaScript 。
网页设计:HTML和CSS基础知识的学习
HTML是网页内容的载体。内容就是网页制作者放在页面上想要让用户浏览的信息,可以包含文字、图片、视频等。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
CSS样式是表现。就像网页的外衣。比如,标题字体、颜色变化,或为标题加入背景图片、边框等。所有这些用来改变内容外观的东西称之为表现。
动态交互:JavaScript基础的学习
JavaScript是用来实现网页上的特效效果。如:鼠标滑过弹出下拉菜单。或鼠标滑过表格的背景颜色改变。还有焦点新闻(新闻图片)的轮换。可以这么理解,有动画的,有交互的一般都是用JavaScript来实现的。