angular2中實(shí)現(xiàn)百度百科導(dǎo)航欄的效果

這是在百度百科中的效果


Paste_Image.png

下面我們開始在ng2中實(shí)現(xiàn)
1.用一套數(shù)據(jù)綁定兩個(gè)區(qū)域:主頁面和導(dǎo)航欄

Paste_Image.png

html代碼:

<main class="teaching_plan_unit">
<!--導(dǎo)航欄-->
  <section class="navigate">
    <p class="top"><span></span></p>
    <p class="text" (click)="onTab(item)" [ngClass]="{active: activeId==item.id}" *ngFor="let item of _atomicTeachPlan.oTeachPlanModuleList">{{item.moduleTitle}}</p>
    <p class="end"><span></span></p>
  </section>
  <section appScroll (onTabChange)="onTabChange($event)">
<!--主頁面-->
    <examination-question-module *ngFor="let item of _atomicTeachPlan?.oTeachPlanModuleList" [id]="'module_'+item.id" [teachPlanModule]="item" [state]="_state"></examination-question-module>
  </section>
</main>

component:

import { Component, OnInit, Input, ElementRef } from '@angular/core';

@Component({
    selector: 'teaching-plan-unit',
    styleUrls: ['teaching-plan.component.css'],
    templateUrl: 'teaching-plan-unit.component.html'
})
export class TeachingPlanUnitComponent implements OnInit {
    _state: string;     // preview預(yù)覽漾月;edit編輯
    _atomicTeachPlan: any;
    activeId: string = '1';
    @Input()
    set state(state) {
        this._state = state;
    }
    @Input()
    set atomicTeachPlan(atomicTeachPlan) {
        this._atomicTeachPlan = atomicTeachPlan;
    }
    constructor(private el: ElementRef) { }

    ngOnInit() { }

    onTab(module) {
        let id = 'module_' + module.id;
        this.setActive(module.id);
        let moduleDom = this.el.nativeElement.children[0].lastElementChild.children;
        for (let i = 0; i < moduleDom.length; i++) {
            if (moduleDom[i].id === id) {
                document.body.scrollTop = moduleDom[i].offsetTop;
            }
        }
    }

    setActive(index: string) {
        this.activeId = index;
    }

    onTabChange(top) {
        let moduleDom = this.el.nativeElement.children[0].lastElementChild.children;
        for (let i = 1; i < moduleDom.length; i++) {
            if (moduleDom[i].offsetTop > top && moduleDom[i-1].offsetTop <= top) {
                let index = moduleDom[i-1].id.split('module_')[1];
                this.setActive(index);
            }
        }
    }
}

directive

import { Directive, HostListener, ElementRef, Input, EventEmitter, Output } from '@angular/core';

@Directive({
    selector: '[appScroll]'
})
export class ScrollDirective {
    @Output() onTabChange: EventEmitter<number> = new EventEmitter<number>();

    constructor(private el: ElementRef) {}

    @HostListener('mousewheel', ['$event']) onMouseWheelChrome() {
        this.onTabChange.emit(document.body.scrollTop);
    }
}

分兩個(gè)部分:
1.點(diǎn)擊導(dǎo)航欄定位到相應(yīng)的模塊
(1)點(diǎn)擊設(shè)置導(dǎo)航欄激活狀態(tài)病梢,獲取相應(yīng)模塊的id值(或者data-top獲取滾動(dòng)距離)
(2)ElementRef定位到相應(yīng)的模塊,操作Dom,將滾動(dòng)條移動(dòng)到相應(yīng)的位置去

2.監(jiān)聽鼠標(biāo)滾動(dòng)判斷導(dǎo)航欄激活狀態(tài)
(1)指令中HostListener獲取滾動(dòng)事件
(2)傳回滾動(dòng)條距離
(3)導(dǎo)航欄根據(jù)滾動(dòng)距離判斷激活狀態(tài)

關(guān)于ng2監(jiān)聽鼠標(biāo)事件蜓陌,可參考:
http://www.tuicool.com/articles/eii2yaB

import { Directive, Output, HostListener, EventEmitter } from '@angular/core';
@Directive({ selector: '[mouseWheel]' })export class MouseWheelDirective { 
  @Output() mouseWheelUp = new EventEmitter(); 
  @Output() mouseWheelDown = new EventEmitter(); 
  @HostListener('mousewheel', ['$event']) onMouseWheelChrome(event: any) { this.mouseWheelFunc(event); } 
  @HostListener('DOMMouseScroll', ['$event']) onMouseWheelFirefox(event: any) { this.mouseWheelFunc(event); }
  @HostListener('onmousewheel', ['$event']) onMouseWheelIE(event: any) { this.mouseWheelFunc(event); }
  mouseWheelFunc(event: any) {
    var event = window.event || event; // old IE support var delta = Math.max(-1, Math.min(1, (event.wheelDelta || -event.detail))); 
    if(delta > 0) { this.mouseWheelUp.emit(event); } 
    else if(delta < 0) { this.mouseWheelDown.emit(event); } // for IE event.
    returnValue = false; // for Chrome and Firefox if(event.preventDefault) { event.preventDefault(); } }}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末觅彰,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子钮热,更是在濱河造成了極大的恐慌填抬,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件隧期,死亡現(xiàn)場(chǎng)離奇詭異飒责,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)仆潮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門宏蛉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人性置,你說我怎么就攤上這事拾并。” “怎么了鹏浅?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵嗅义,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我隐砸,道長(zhǎng)之碗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任季希,我火速辦了婚禮褪那,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胖眷。我一直安慰自己武通,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布珊搀。 她就那樣靜靜地躺著冶忱,像睡著了一般。 火紅的嫁衣襯著肌膚如雪境析。 梳的紋絲不亂的頭發(fā)上囚枪,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音劳淆,去河邊找鬼链沼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛沛鸵,可吹牛的內(nèi)容都是我干的括勺。 我是一名探鬼主播缆八,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼疾捍!你這毒婦竟也來了奈辰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤乱豆,失蹤者是張志新(化名)和其女友劉穎奖恰,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宛裕,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瑟啃,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了揩尸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛹屿。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖疲酌,靈堂內(nèi)的尸體忽然破棺而出蜡峰,到底是詐尸還是另有隱情,我是刑警寧澤朗恳,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站载绿,受9級(jí)特大地震影響粥诫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜崭庸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一怀浆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧怕享,春花似錦执赡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至跌帐,卻和暖如春首懈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谨敛。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工究履, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人脸狸。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓最仑,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子泥彤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,734評(píng)論 25 707
  • 你是否見過有些人面對(duì)壓力情緒時(shí)能泰然處之紊搪,穩(wěn)如泰山,而有的人側(cè)表現(xiàn)的唉聲嘆氣全景、暴跳如雷耀石? 你是否認(rèn)為有錢就一定幸福...
    牛萬里閱讀 1,997評(píng)論 4 0
  • 當(dāng)周圍的有人忙忙碌碌時(shí),不要受其影響爸黄,因?yàn)榛艁y后的行為會(huì)散發(fā)出不可估量的愚蠢氣味 有安逸生活時(shí)滞伟,就好好享受此時(shí)的安...
    好海子閱讀 337評(píng)論 0 0
  • 從1988年太陽神創(chuàng)業(yè)開始,主打品牌就是太陽神生物健口服液和猴頭菇口服液炕贵,這兩只產(chǎn)品創(chuàng)造了太陽神的輝煌梆奈。可是在隨后...
    與夢(mèng)閱讀 621評(píng)論 0 0
  • 漫長(zhǎng)的飛機(jī)旅途讓林媛曼有些困意称开,她頭靠著窗聽著他的家人談笑風(fēng)生亩钟。這是林媛曼第一次搬家,從靈舊搬到墨城鳖轰,靈舊是個(gè)...
    浮煙釀閱讀 102評(píng)論 0 0