今天就跟大家聊聊有关angular4中怎么实现子路由和辅助路由,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
目前成都创新互联已为成百上千家的企业提供了网站建设、域名、雅安服务器托管、网站托管、企业网站设计、云阳网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
1.设置根路由入口:在模板(html)上设置,路由入口就是点击哪里开始路由到新组件(点击首页到首页去)
<a [routerLink]="['/']">主页</a> <a [routerLink]="['/product']" [queryParams]="{id:1}">商品详情</a> <a [routerLink]="['/home',2]">主页</a>
子路由入口:(子路由是./)字路由是路由里面套的路由可以无限嵌套。
<a [routerLink]="['./']">商品描述</a> <a [routerLink]="['./seller',99]">商品描述</a>
路由出口(路由出口是指新的组件将在哪里显示。入口指定什么时候加载新组件,出口指加载完的组件显示在哪里):路由的出口和入口均在模板里面设置
<router-outlet></router-outlet>
路由路径:当路由的出口入口都设置好了的时候就来配置路由的路径。路径指定了当访问哪条路径的时候加载哪个模板
const routes:Routes=[ {path:'',redirectTo:'/home',pathMatch:'full'}, {path:'product',component:ProductComponent,children:[ {path:'',component:ProductdescComponent} , {path:'seller/:id',component:SellerComponent} ]}, {path:'home/:id',component:HomeComponent},//整个路径被划分成两段变量,一段是路径,一段时参数 {path:'**',component:Code404Component}//通配符,当路径找不到的时候访问 ];
辅助路由:
分三步:
1.在主路由的插座也就是出口处定义一个辅助路由插座:也就是定义个辅助路由的出口:辅助路由的出口定义和主路由一样,只是辅助路由比主路由多了一个name属性:用来指定辅助路由显示那几个组件
这里指辅助路由显示outlet叫做aux对应的组件
<router-outlet></router-outlet> <router-outlet name="aux"></router-outlet>
2.配置辅助路由路径:必须加一个outlet属性,指定该路由显示在名字叫什么的辅助路由出口(插座)上;
这里指当访问chat时加载XchatComponnet显示在名字叫aux的这个辅助路由出处。
{path:'chat',component:XhatComponent,outlet:'aux'},
3.配置入口参数:辅助路由的参数将是一个对象,这个对象里面有一个属性outlets,这个属性的值也是一个对象,该对象里面传一个name属性指定要显示的辅助路由的名字,值是该辅助路由需要显示的组件路径;比如下面:名字叫aux的辅助路由将显示路径为chat的组件
需要注意的是当不希望辅助路由显示的时候可以吧name设置为null。
这里指点击开始聊天的时候加载路径为chat对应的组件,显示在名字叫做aux的辅助路由出口上。
<a [routerLink]="[{outlets:{aux:'chat'}}]">开始聊天</a> <a [routerLink]="[{outlets:{aux:null}}]">结束聊天</a>
当希望跳转辅助路由的同时主路由跳转到指定的组件的时候:可以在入口文件加一个属性:primary,属性的值是需要跳转的主组件的路由路径例如下面点击聊天的同时不管目前在哪个组件下主路由都会跳转回home路径下的组件
<a [routerLink]="[{outlets:{primary:home, aux:'chat'}}]">开始聊天</a>
看完上述内容,你们对angular4中怎么实现子路由和辅助路由有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。
本文标题:angular4中怎么实现子路由和辅助路由
网页链接:https://www.cdcxhl.com/article42/gchjec.html
成都网站建设公司_创新互联,为您提供面包屑导航、网站收录、网站改版、Google、网站制作、网站设计公司
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联