angular2 animation實(shí)踐

作者介紹:筆者本身并沒(méi)有寫(xiě)過(guò)太多的文章移稳,雖然有自己的個(gè)人博客,但是以前也不會(huì)去養(yǎng)成寫(xiě)文章的習(xí)慣会油。之所以寫(xiě)這篇文章是發(fā)現(xiàn)網(wǎng)上寫(xiě)angular2的animation教程少的可憐秒裕,所以自己實(shí)踐了一些動(dòng)畫(huà),并且將這些過(guò)程記錄下來(lái)钞啸,希望自己以后也能回顧一下几蜻。

首先喇潘,介紹一下angular的animation吧。從angular4開(kāi)始梭稚,animation被獨(dú)立出來(lái)形成了一個(gè)@angular/animations的包颖低。所以記得在使用之前需要安裝一下這個(gè)包。

  npm install @angular/animations --save  (這條命令可以安裝動(dòng)畫(huà))弧烤。

安裝完之后就可以在項(xiàng)目中使用了忱屑。

使用animation前,需要在當(dāng)前組件的Module中導(dǎo)入BrowserAnimationsModule暇昂。這樣才能夠在組件中使用動(dòng)畫(huà)莺戒。

接下來(lái),講一下編寫(xiě)動(dòng)畫(huà)的方法急波,有兩種方式从铲,一種是新建一個(gè)ts文件,在ts文件中編寫(xiě)一個(gè)動(dòng)畫(huà)澄暮,然后導(dǎo)入到組件中名段;另一種方式就是直接在組件中編寫(xiě)。

    //新建的一個(gè)ts文件 animation.ts
    import {trigger,state,translation,style,animate,keyframes} from '@angluar/animations';

    export const fadeIn = trigger(
         ....                     //這是第一種方式
    )

編寫(xiě)好動(dòng)畫(huà)之后泣懊,將其導(dǎo)入component的animations中伸辟。

 import {Component} from '@angular/core';
 import {fadeIn} from './fadeIn.ts';

 @Component({
    animations: [fadeIn],
 ...
 })

上面的這種寫(xiě)法可以將一個(gè)動(dòng)畫(huà)復(fù)用到多個(gè)組件中去,一般寫(xiě)大型項(xiàng)目時(shí)馍刮,建議使用這種方式信夫。但是,我接下來(lái)的小demo將會(huì)使用第二種方式去書(shū)寫(xiě)卡啰。
這個(gè)小demo就是平時(shí)大家都會(huì)用到的下拉列表静稻,下圖是我在寫(xiě)測(cè)試的時(shí)候?qū)懙模?/p>

列表收起時(shí)
列表展開(kāi)時(shí)

這兩張圖是,最終狀態(tài)的結(jié)果圖碎乃,下面來(lái)看一下中間動(dòng)畫(huà)的源代碼:

import { Component } from '@angular/core';
import {trigger, state, style, animate, keyframes, transition} from '@angular/animations';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css'],
  animations: [
    trigger('animation', [
      state('open', style({display: 'block'})),
      state('close', style({display: 'none'})),
      transition('open => close', animate('330ms', keyframes([
        style({height: '*'}),             //離場(chǎng)動(dòng)畫(huà),div塊的高度從自適應(yīng)逐漸變成0
        style({height: '0'})
      ]))),
      transition('close => open', animate('330ms', keyframes([
        style({height: '0'}),            //進(jìn)場(chǎng)動(dòng)畫(huà)惠奸,div塊的高度從0到自適應(yīng)的高度
        style({height: '*'})
      ])))
    ])
  ]
})
export class AppComponent {
  public state = 'close';

  public changeOpen() {             //點(diǎn)擊展開(kāi)按鈕時(shí)梅誓,div塊進(jìn)場(chǎng)
    this.state = 'open';
  }

  public changeClose() {                //點(diǎn)擊離開(kāi)按鈕時(shí),div塊離場(chǎng)
    this.state = 'close';
  }
}

整個(gè)動(dòng)畫(huà)有兩個(gè)狀態(tài)‘open’和'close'佛南,打開(kāi)時(shí)open梗掰,div塊是顯示的,close時(shí)嗅回,div塊時(shí)隱藏的及穗。在整個(gè)div塊有一個(gè)進(jìn)場(chǎng)的動(dòng)畫(huà)和離場(chǎng)的動(dòng)畫(huà)峰弹。
下面是整個(gè)小測(cè)試的html和css源碼

<button (click)="changeOpen()">展開(kāi)</button>
<div class="test-div" [@animation]="state">
  <ul>
    <li>測(cè)試</li>
    <li>測(cè)試</li>
    <li>測(cè)試</li>
    <li>測(cè)試</li>
    <li>測(cè)試</li>
    <li>測(cè)試</li>
  </ul>
</div>
<button (click)="changeClose()">收起</button>
.test-div{
  width: 100px;
  position: relative;
  overflow: hidden;
}

.test-div ul{
  list-style: none;
}

這個(gè)小動(dòng)畫(huà)能夠在很多的小場(chǎng)景下使用匀奏,如圖:

下拉菜單

這是第一次在簡(jiǎn)書(shū)寫(xiě)文章,我也只是想寫(xiě)點(diǎn)有意思的前端小玩意呐赡,然后將實(shí)現(xiàn)的過(guò)程記錄下來(lái),方便以后查看焚虱。
注:這篇博文屬于原創(chuàng)博文购裙,如果有問(wèn)題的可以給我留言,轉(zhuǎn)載注明出處鹃栽。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末躏率,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子民鼓,更是在濱河造成了極大的恐慌薇芝,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丰嘉,死亡現(xiàn)場(chǎng)離奇詭異夯到,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)供嚎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)黄娘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人克滴,你說(shuō)我怎么就攤上這事逼争。” “怎么了劝赔?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵誓焦,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我着帽,道長(zhǎng)杂伟,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任仍翰,我火速辦了婚禮赫粥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘予借。我一直安慰自己越平,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布灵迫。 她就那樣靜靜地躺著秦叛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瀑粥。 梳的紋絲不亂的頭發(fā)上挣跋,一...
    開(kāi)封第一講書(shū)人閱讀 51,554評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音狞换,去河邊找鬼避咆。 笑死舟肉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的牌借。 我是一名探鬼主播度气,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼膨报!你這毒婦竟也來(lái)了磷籍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤现柠,失蹤者是張志新(化名)和其女友劉穎院领,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體够吩,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡比然,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了周循。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片强法。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖湾笛,靈堂內(nèi)的尸體忽然破棺而出饮怯,到底是詐尸還是另有隱情,我是刑警寧澤嚎研,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布蓖墅,位于F島的核電站,受9級(jí)特大地震影響临扮,放射性物質(zhì)發(fā)生泄漏论矾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一杆勇、第九天 我趴在偏房一處隱蔽的房頂上張望贪壳。 院中可真熱鬧,春花似錦蚜退、人聲如沸闰靴。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)传黄。三九已至杰扫,卻和暖如春队寇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背章姓。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工佳遣, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留识埋,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓零渐,卻偏偏與公主長(zhǎng)得像窒舟,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子诵盼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)惠豺、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,103評(píng)論 4 62
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,135評(píng)論 25 707
  • 小姨其實(shí)不小,將近六十歲的年紀(jì)戒财,怎么樣都跟“小”有些區(qū)別热监。之所以叫她小姨,是因?yàn)椴幌胨敲纯炖先ヒ胱寱r(shí)光走的慢一...
    碼字的黃小邪閱讀 658評(píng)論 0 3
  • 剛好 得意 說(shuō)你
    hahaqwer閱讀 372評(píng)論 0 51
  • 當(dāng)她打開(kāi)電梯門(mén)幽崩,與他四目相對(duì)苦始,在電梯里的每一秒都顯得極為尷尬。她站在他的左側(cè)歉铝,無(wú)所適從拿起手機(jī)翻過(guò)去翻過(guò)來(lái)盈简;他低下...
    湯湯_9143閱讀 287評(píng)論 0 0