欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

angular4實(shí)現(xiàn)tab欄切換的方法示例

管理系統(tǒng) tab 切換頁(yè),是一種常見的需求,大概如下:

公司主營(yíng)業(yè)務(wù):網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。成都創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出萊山免費(fèi)做網(wǎng)站回饋大家。

angular4實(shí)現(xiàn)tab欄切換的方法示例

點(diǎn)擊左邊菜單,右邊顯示相應(yīng)的選項(xiàng)卡,然后不同的選項(xiàng)卡面可以同時(shí)編輯,切換時(shí)信息不掉失!

用php或.net,java的開發(fā)技術(shù),大概是切換顯示,然后加一個(gè)ifram來做到,或者通過ajax加載信息顯示相應(yīng)的層.

但是如果用angular 要如何實(shí)現(xiàn)呢?第一個(gè)想法,是否可以用同樣的ifarm來實(shí)現(xiàn)呢?

第二個(gè)想到的是路由插座大概是這樣的

復(fù)制代碼 代碼如下:

<router-outlet name="main-content" (activate)="activate($event)" (deactivate)='onDeactivate($event)' ></router-outlet>

但都沒能實(shí)現(xiàn),于是在想一個(gè)簡(jiǎn)單的tab頁(yè)面就這么難嗎?

或者真的沒有什么簡(jiǎn)單的方法了嗎?

很長(zhǎng)一段時(shí)間,沒有去管這個(gè)了

因?yàn)槲抑雷约簩?duì)angular的理解和學(xué)習(xí)還不夠,于是就放下了很長(zhǎng)一段時(shí)間,直到在知乎看到一篇文章

Angular路由復(fù)用策略

于是有了一種思路,花了半天的時(shí)間終于實(shí)現(xiàn)了anguar 4  tab 切換頁(yè)大概思路實(shí)現(xiàn)如下:

一、實(shí)現(xiàn) RouteReuseStrategy 接口自定義一個(gè)路由利用策略

SimpleReuseStrategy.ts代碼如下:

import { RouteReuseStrategy, DefaultUrlSerializer, ActivatedRouteSnapshot, DetachedRouteHandle } from '@angular/router';

export class SimpleReuseStrategy implements RouteReuseStrategy {

  public static handlers: { [key: string]: DetachedRouteHandle } = {}

  /** 表示對(duì)所有路由允許復(fù)用 如果你有路由不想利用可以在這加一些業(yè)務(wù)邏輯判斷 */
  public shouldDetach(route: ActivatedRouteSnapshot): boolean {
    return true;
  }

  /** 當(dāng)路由離開時(shí)會(huì)觸發(fā)。按path作為key存儲(chǔ)路由快照&組件當(dāng)前實(shí)例對(duì)象 */
  public store(route: ActivatedRouteSnapshot, handle: DetachedRouteHandle): void {
    SimpleReuseStrategy.handlers[route.routeConfig.path] = handle
  }

  /** 若 path 在緩存中有的都認(rèn)為允許還原路由 */
  public shouldAttach(route: ActivatedRouteSnapshot): boolean {
    return !!route.routeConfig && !!SimpleReuseStrategy.handlers[route.routeConfig.path]
  }

  /** 從緩存中獲取快照,若無則返回nul */
  public retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle {
    if (!route.routeConfig) {
      return null
    }
    
    return SimpleReuseStrategy.handlers[route.routeConfig.path]
  }

  /** 進(jìn)入路由觸發(fā),判斷是否同一路由 */
  public shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
    return future.routeConfig === curr.routeConfig
  }
}

二、策略注冊(cè)到模塊當(dāng)中:

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { CommonModule as SystemCommonModule } from '@angular/common';
import { AppComponent } from './app.component';
import { AppRoutingModule,ComponentList } from './app.routing'
import { SimpleReuseStrategy } from './SimpleReuseStrategy';
import { RouteReuseStrategy } from '@angular/router';

@NgModule({
 declarations: [
  AppComponent,
  ComponentList
 ],
 imports: [
  BrowserModule,
  AppRoutingModule,
  FormsModule,
  SystemCommonModule
 ],
 providers: [
  { provide: RouteReuseStrategy, useClass: SimpleReuseStrategy }
 ],
 bootstrap: [AppComponent]
})
export class AppModule { }

上面兩步基本上實(shí)現(xiàn)了復(fù)用策略但要實(shí)現(xiàn)第一張效果圖,還是要做一些其它工作

三、定義路由添加一些data數(shù)據(jù)路由代碼如下:

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { AboutComponent } from './home/about.component'
import { HomeComponent } from './home/home.component'
import { NewsComponent } from './home/news.component'
import { ContactComponent } from './home/contact.component'



export const routes: Routes = [
 { path: '', redirectTo: 'home', pathMatch: 'full', },
 { path: 'home', component: HomeComponent,data: { title: '首頁(yè)', module: 'home', power: "SHOW" } },
 { path: 'news',component: NewsComponent ,data: { title: '新聞管理', module: 'news', power: "SHOW" }},
 { path: 'contact',component: ContactComponent ,data: { title: '聯(lián)系我們', module: 'contact', power: "SHOW" }},
 { path: 'about', component: AboutComponent,data: { title: '關(guān)于我們', module: 'about', power: "SHOW" } },
];

@NgModule({
 imports: [RouterModule.forRoot(routes)],
 exports: [RouterModule]
})

export class AppRoutingModule { }

export const ComponentList=[
  HomeComponent,
  NewsComponent,
  AboutComponent,
  ContactComponent
]

四、在<router-outlet></router-outlet> component 實(shí)現(xiàn)路由事件  events,app.component代碼如下:

import { Component } from '@angular/core';
import { SimpleReuseStrategy } from './SimpleReuseStrategy';
import { ActivatedRoute, Router, NavigationEnd } from '@angular/router';
import { Title } from '@angular/platform-browser';
import 'rxjs/add/operator/filter';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/mergeMap';

@Component({
 selector: 'app-root',
 styleUrls:['app.css'],
 templateUrl: 'app.html',
 providers: [SimpleReuseStrategy]
})

export class AppComponent {
 
 //路由列表
 menuList: Array<{ title: string, module: string, power: string,isSelect:boolean }>=[];

 constructor(private router: Router,
  private activatedRoute: ActivatedRoute,
  private titleService: Title) {
 
  //路由事件
  this.router.events.filter(event => event instanceof NavigationEnd)
   .map(() => this.activatedRoute)
   .map(route => {
    while (route.firstChild) route = route.firstChild;
    return route;
   })
   .filter(route => route.outlet === 'primary')
   .mergeMap(route => route.data)
   .subscribe((event) => {
    //路由data的標(biāo)題
    let title = event['title'];
    this.menuList.forEach(p => p.isSelect=false);
    var menu = { title: title, module: event["module"], power: event["power"], isSelect:true};
    this.titleService.setTitle(title);
    let exitMenu=this.menuList.find(info=>info.title==title);
    if(exitMenu){//如果存在不添加,當(dāng)前表示選中
     this.menuList.forEach(p => p.isSelect=p.title==title);
     return ;
    } 
    this.menuList.push(menu);
   });
 }

 //關(guān)閉選項(xiàng)標(biāo)簽
 closeUrl(module:string,isSelect:boolean){
  //當(dāng)前關(guān)閉的是第幾個(gè)路由
  let index=this.menuList.findIndex(p=>p.module==module);
  //如果只有一個(gè)不可以關(guān)閉
  if(this.menuList.length==1) return ;

  this.menuList=this.menuList.filter(p=>p.module!=module);
  //刪除復(fù)用
  delete SimpleReuseStrategy.handlers[module];
  if(!isSelect) return;
  //顯示上一個(gè)選中
  let menu=this.menuList[index-1];
  if(!menu) {//如果上一個(gè)沒有下一個(gè)選中
    menu=this.menuList[index+1];
  }
  // console.log(menu);
  // console.log(this.menuList);
  this.menuList.forEach(p => p.isSelect=p.module==menu.module );
  //顯示當(dāng)前路由信息
  this.router.navigate(['/'+menu.module]);
 }
}
import { Component } from '@angular/core';
import { SimpleReuseStrategy } from './SimpleReuseStrategy';
import { ActivatedRoute, Router, NavigationEnd } from '@angular/router';
import { Title } from '@angular/platform-browser';
import 'rxjs/add/operator/filter';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/mergeMap';

@Component({
 selector: 'app-root',
 styleUrls:['app.css'],
 templateUrl: 'app.html',
 providers: [SimpleReuseStrategy]
})

export class AppComponent {
 
 //路由列表
 menuList: Array<{ title: string, module: string, power: string,isSelect:boolean }>=[];

 constructor(private router: Router,
  private activatedRoute: ActivatedRoute,
  private titleService: Title) {
 
  //路由事件
  this.router.events.filter(event => event instanceof NavigationEnd)
   .map(() => this.activatedRoute)
   .map(route => {
    while (route.firstChild) route = route.firstChild;
    return route;
   })
   .filter(route => route.outlet === 'primary')
   .mergeMap(route => route.data)
   .subscribe((event) => {
    //路由data的標(biāo)題
    let title = event['title'];
    this.menuList.forEach(p => p.isSelect=false);
    var menu = { title: title, module: event["module"], power: event["power"], isSelect:true};
    this.titleService.setTitle(title);
    let exitMenu=this.menuList.find(info=>info.title==title);
    if(exitMenu){//如果存在不添加,當(dāng)前表示選中
     this.menuList.forEach(p => p.isSelect=p.title==title);
     return ;
    } 
    this.menuList.push(menu);
   });
 }

 //關(guān)閉選項(xiàng)標(biāo)簽
 closeUrl(module:string,isSelect:boolean){
  //當(dāng)前關(guān)閉的是第幾個(gè)路由
  let index=this.menuList.findIndex(p=>p.module==module);
  //如果只有一個(gè)不可以關(guān)閉
  if(this.menuList.length==1) return ;

  this.menuList=this.menuList.filter(p=>p.module!=module);
  //刪除復(fù)用
  delete SimpleReuseStrategy.handlers[module];
  if(!isSelect) return;
  //顯示上一個(gè)選中
  let menu=this.menuList[index-1];
  if(!menu) {//如果上一個(gè)沒有下一個(gè)選中
    menu=this.menuList[index+1];
  }
  // console.log(menu);
  // console.log(this.menuList);
  this.menuList.forEach(p => p.isSelect=p.module==menu.module );
  //顯示當(dāng)前路由信息
  this.router.navigate(['/'+menu.module]);
 }
}

app.html 的代碼如下:

<div class="row">
 <div class="col-md-4">
  <ul>
   <li><a routerLinkActive="active" routerLink="/home">首頁(yè)</a></li>
   <li><a routerLinkActive="active" routerLink="/about">關(guān)于我們</a></li>
   <li><a routerLinkActive="active" routerLink="/news">新聞中心</a></li>
   <li><a routerLinkActive="active" routerLink="/contact">聯(lián)系我們</a></li>
  </ul>
 </div>
 <div class="col-md-8">
  <div class="crumbs clearfix">
   <ul>
     <ng-container *ngFor="let menu of menuList">
       <ng-container *ngIf="menu.isSelect">
         <li class="isSelect">
           <a routerLink="/{{ menu.module }}">{{ menu.title }}</a> 
           <span (click)="closeUrl(menu.module,menu.isSelect)">X</span> 
         </li>
       </ng-container>
       <ng-container *ngIf="!menu.isSelect">
         <li>
           <a routerLink="/{{ menu.module }}">{{ menu.title }}</a> 
           <span (click)="closeUrl(menu.module,menu.isSelect)">X</span> 
         </li>
       </ng-container>
     </ng-container>
   </ul>
  </div>
  <router-outlet></router-outlet>
 </div>
</div>

 整體效果如下:

angular4實(shí)現(xiàn)tab欄切換的方法示例

最終點(diǎn)擊菜單顯示相應(yīng)的標(biāo)簽選中,可以切換編輯內(nèi)容,關(guān)閉標(biāo)簽時(shí),重新點(diǎn)擊菜單可以重新加載內(nèi)容。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

當(dāng)前標(biāo)題:angular4實(shí)現(xiàn)tab欄切換的方法示例
當(dāng)前URL:http://aaarwkj.com/article46/jejseg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)靜態(tài)網(wǎng)站、用戶體驗(yàn)、微信公眾號(hào)Google、網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
人妖激情一区二区三区| 亚洲国产日韩欧美视频| 亚洲天堂国产中文在线| 三级国产大片在线观看| 亚洲免费视频一二三区| 四虎免费在线视频观看| 亚洲日本国产一区二区| 尤物欧美精品一区二区三区| 久久人妻制服乱码中文字幕| 色综合天天综合天天更新| 国产婷婷精品一区二区| 国产一区二区高清在线| 日本丰满熟女毛茸茸的黑逼| 人妻的秘密一区二区三区 | 亚洲婷婷久久一区二区| 一级丰满少妇av大片| 亚洲精品在线观看日本| 五月婷婷六月丁香综合激情| 成人黄色动作片在线观看| 亚洲精品露脸自拍高清在线观看| 91超碰在线观看中文| 国产精品粉嫩在线播放| 熟女人妻视频一区二区| 亚洲黄色片大奶子水多| 6080yy精品一区二区三区| 久久成人综合亚洲精品欧美| 国产伦精品一区二区三区免费视频| 欧美高清成人一区二区三区| 日本高清一区二区不卡视频 | 国产日韩欧美国产精品| 亚洲少妇精品视频在线| 亚洲中文字幕一区二区人妻| 国产亚洲精品久久久9| 97久久成人国产精品免费| 色婷婷丝袜一区网站| 青青草原一区二区三区| 欧美成人精品视频在线不卡| 亚洲日本精品国产第一区| 在线观看国产小视频不卡| 国产精品果亚洲av无人区一区| 亚洲 欧美 日韩一区|