最近开始学习angular框架,路由部分怎么学呢?我想通过自己一边写demo,一边用文字记录下这个过程,让自己学习到的内容更加深刻。以下就开始直播学习过程:
一、安装路由文件到模版
首先,用ngcli新建一个配置好路由文件名为“ngRouter”的项目:
在命令工具输入
ng new ngRouter --routing
安装完毕后,会在项目文件中的src/app中看到一个名为“app-routing.module.ts”的文件,
data:image/s3,"s3://crabby-images/2d11c/2d11cde72d9ef5b8cf905c2f2eca5c1db5f414a3" alt=""
里面的代码是这样的:
import{NgModule}from'@angular/core'; //第一行
import{Routes,RouterModule}from'@angular/router'; //第二行
const routes:Routes=[]; //第三行
@NgModule({ //第四行
imports:[RouterModule.forRoot(routes)], //第五行
exports:[RouterModule] //第六行
})
export class AppRoutingModule { } //第七行
代码中的第一行是导入NgModule,第二行导入配置路由用的Routes和RouterModule类,第三行声明一个Routes类型的常量,用以配置路由的参数,第五行是将定义的路由注入到NgModule中,第七行是本文件的出口,会在“app.module.ts”文件中导入:
data:image/s3,"s3://crabby-images/e5d3f/e5d3f23c11302262f725d3cbf178308410114166" alt=""
二、新建两个用于演示的组件
在命令行工具中输入
data:image/s3,"s3://crabby-images/49552/495523ab7c1eeffdcdb747a320c00913eb1c2652" alt=""
在项目中生成了两个组件(demo1和demo2)
data:image/s3,"s3://crabby-images/71ad4/71ad4ed9c8e16497f5fcdd8daf2dac5b1511fc61" alt=""
三、实现简单的路由
到“app-routing.module.ts”文件,给routes常量赋值,即在中括号中输入内容,routes是一个数组,元素可以看作是每一个要配置的路由。在这,分别给demo1和demo2配置路由,输入内容如下:
data:image/s3,"s3://crabby-images/caa7f/caa7f2efd30a9489103638758a1dc115e80405cf" alt=""
在app组件中写入可以实现跳转的a标签,“app.component.html”的内容写成:
data:image/s3,"s3://crabby-images/84287/842874665a5b4335e4b166363f8d647babb1922c" alt=""
接着运行在浏览器中(在命令行工具输入npm start)
页面中出了:
data:image/s3,"s3://crabby-images/7609f/7609f3083198a0032b37261e9aa618658db4994d" alt=""
点击之后就会显示相应的组件
3.1路由重定向
如果需要进入主页就开始显示组件demo1的内容,则在“app-routing.module.ts”配置对应的属性,如下:
data:image/s3,"s3://crabby-images/dfd9f/dfd9f8cc96cc636358877f9dd443fbcd27213840" alt=""
3.2按钮实现跳转
不论是什么元素的什么事件,都可以触发路由跳转。用简单的按钮点击事件作示范:
首先,在“app.component.html”中添加一个按钮:
data:image/s3,"s3://crabby-images/64a2f/64a2f6b11c10aca642a8be54a7396929509066f5" alt=""
接着,在“app.component.ts”中定义点击相对应的函数(这里是"linkToDemo2"):
data:image/s3,"s3://crabby-images/7dd29/7dd2983ef4f29c6669a6e04422b62d5fb18db80a" alt=""
这样点击按钮就可以跳转路由了。
注意:需要导入Router,然后在构造函数中注入,写在navigate的参数是个数组。
3.3无定义路由跳转到404页面
在现实中,如果用户输入路由错误或没有定义的路由,这时,应该跳转到一个404页面。项目中,实现的步骤如下:
1、写好一个404页面组件,并写上要显示的内容。
data:image/s3,"s3://crabby-images/f25fa/f25fa75a7aac8c18574f339348d40fee1700135e" alt=""
2、在路由中设置好配置
data:image/s3,"s3://crabby-images/cbbdb/cbbdb5efb40de6df88739fb6b5c1b67f2d00ef5b" alt=""
关键: 这里用到了“**”作通配符,一定要把这个对象放到最后,因为,路由是按顺序找组件的,如果放在前面,就首先跳到404组件,不会再找后面的组件。
3.4路由传参的应用
在路由中定义一个参数,用户输入是什么值,那么这个参数就被定义成什么值,简单的应用如下:
data:image/s3,"s3://crabby-images/ebf85/ebf8586016107260870095fd5973057fa1087ace" alt=""
我demo1的路由中添加了id的参数,当我要在页面中使用这个参数时,那么,需要在组件中的TS文件写些代码,本例是在“demo1.component.ts”中写,如果我要动态显示这个参数:
1、在“demo1.component.ts”写:
data:image/s3,"s3://crabby-images/4829b/4829bb2de4a24f0a5eabcb66722053c1212827e5" alt=""
2、在相应的HTML文件就可以使用定义好的变量了(我定义成userId)
data:image/s3,"s3://crabby-images/19cd5/19cd511dfbfd5af7dc17d0225c0e6b29668568f4" alt=""
效果:
data:image/s3,"s3://crabby-images/82e34/82e34befef8e2f507523cab3ca78b2f9462cdcbf" alt=""
当然,可以在a标签中写好id
data:image/s3,"s3://crabby-images/86db3/86db306a01b0f1442b36a94a8a6029095872e79b" alt=""
还有,另外一种方法,写参数
data:image/s3,"s3://crabby-images/4ed28/4ed289133c95ac4e66ca160ca8443519c8862eb9" alt=""
还有还有,另外一种方法传参数:
data:image/s3,"s3://crabby-images/2501a/2501a4f1bca113acf66d51aee1662b8c442fb6d2" alt=""
然后,在“demo1.component.ts”中写成:
data:image/s3,"s3://crabby-images/dbbfe/dbbfea66922ba97eddfad31e187fc99421037fe5" alt=""
路径是会就这样的
data:image/s3,"s3://crabby-images/2d470/2d4708d7b5eb10caa97fd9cd8c5757a4d87aa535" alt=""
最后,还有一种传数据的方法:
在路由配置文件中,加上属性data:
data:image/s3,"s3://crabby-images/561e4/561e483925e93440bf1f9f828f38e786f4a1a565" alt=""
在“demo1.component.ts”中写成:
data:image/s3,"s3://crabby-images/b6d89/b6d89e2c023cb7c39106b8b6f53123b33e3ec753" alt=""
--------------------------------------------------------------------------------
路由基本的应用就写到这里了,后面还有一个路由防卫,接下来将另写一篇走一遍。
总结
介绍了模块导入路由,用两个简单的组件演示了路由的使用,包括了:普通跳转、事件触发跳转、路由重定向、无定义的路由跳转到404组件和路由的数据传输。
网友评论