摘要:效果預覽按下右側的點擊預覽按鈕可以在當前頁面預覽,點擊鏈接可以全屏預覽??山换ヒ曨l此視頻是可以交互的,你可以隨時暫停視頻,編輯視頻中的代碼。
效果預覽
按下右側的“點擊預覽”按鈕可以在當前頁面預覽,點擊鏈接可以全屏預覽。
https://codepen.io/comehope/pen/LJmpXZ
可交互視頻此視頻是可以交互的,你可以隨時暫停視頻,編輯視頻中的代碼。
請用 chrome, safari, edge 打開觀看。
https://scrimba.com/p/pEgDAM/cdD8WHV
源代碼下載每日前端實戰系列的全部源代碼請從 github 下載:
https://github.com/comehope/front-end-daily-challenges
代碼解讀定義 dom,容器包含 2 個元素,branch 代表枝,leaves 代表葉,葉有 6 個子元素,代表 6 個葉片:
居中顯示:
body { margin: 0; height: 100vh; display: flex; align-items: center; justify-content: center; background-color: black; }
定義容器尺寸,并設置子元素水平居中:
.sapling { position: relative; width: 5em; height: 17.5em; font-size: 10px; display: flex; justify-content: center; }
畫出樹枝:
.branch { position: absolute; width: 0.2em; height: inherit; border-radius: 25%; background: burlywood; }
定義樹葉容器,設置為葉片在垂直方向均勻分布,并且從下到上排列:
.leaves { position: absolute; width: inherit; height: 15em; top: 1em; display: flex; flex-direction: column-reverse; }
設置葉片的尺寸和和背景顏色:
.leaves span { width: 2.5em; height: 2.5em; background-color: limegreen; }
設置左右葉片的各自樣式:
.leaves span:nth-child(odd) { border-bottom-left-radius: 3em; border-top-right-radius: 3em; transform-origin: right bottom; align-self: flex-start; } .leaves span:nth-child(even) { border-bottom-right-radius: 3em; border-top-left-radius: 3em; transform-origin: left bottom; align-self: flex-end; }
至此,靜態效果繪制完成,接下來開始寫動畫腳本。
引入 GSAP 庫:
聲明一個時間線對象:
let animation = new TimelineMax();
增加樹枝的入場動畫效果,并為這個動畫設置一個標簽 branch:
animation.from(".branch", 4, {scaleY: 0, ease: Power1.easeOut}, "branch");
增加樹葉的入場動畫效果,它的參數中有 3 個 0.5,從左到右的含義分別是動畫時長、多個葉片動畫的間隔時長、相對 branch 標簽動畫的延遲時間:
animation.from(".branch", 4, {scaleY: 0, ease: Power1.easeOut}, "branch") .staggerFrom(".leaves span", 0.5, {scale: 0, ease: Power1.easeOut}, 0.5, 0.5, "branch");
增加葉片變黃的動畫效果:
animation.from(".branch", 4, {scaleY: 0, ease: Power1.easeOut}, "branch") .staggerFrom(".leaves span", 0.5, {scale: 0, ease: Power1.easeOut}, 0.5, 0.5, "branch") .to([".branch", ".leaves span"], 3, {backgroundColor: "yellow"});
增加淡出效果:
animation.from(".branch", 4, {scaleY: 0, ease: Power1.easeOut}, "branch") .staggerFrom(".leaves span", 0.5, {scale: 0, ease: Power1.easeOut}, 0.5, 0.5, "branch") .to([".branch", ".leaves span"], 3, {backgroundColor: "yellow"}) .to([".branch", ".leaves span"], 1, {autoAlpha: 0});
修改聲明時間線的代碼,使動畫重復播放:
let animation = new TimelineMax({repeat: -1, repeatDelay: 0.5});
大功告成!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/113930.html
摘要:效果預覽按下右側的點擊預覽按鈕可以在當前頁面預覽,點擊鏈接可以全屏預覽??山换ヒ曨l此視頻是可以交互的,你可以隨時暫停視頻,編輯視頻中的代碼。 showImg(https://segmentfault.com/img/bVbgSKa?w=400&h=302); 效果預覽 按下右側的點擊預覽按鈕可以在當前頁面預覽,點擊鏈接可以全屏預覽。 https://codepen.io/comehop...
摘要:過往項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份發布的項目前端每日實戰專欄每天分解一個前端項目,用視頻記錄編碼過程,再配合詳細的代碼解讀,是學習前端開發的活的參考書 過往項目 2018 年 8 月份項目匯總(共 29 個項目) 2018 年 7 月份項目匯總(共 29 個項目) 2018 年 6 月份項目匯總(...
摘要:過往項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份發布的項目前端每日實戰專欄每天分解一個前端項目,用視頻記錄編碼過程,再配合詳細的代碼解讀,是學習前端開發的活的參考書 過往項目 2018 年 8 月份項目匯總(共 29 個項目) 2018 年 7 月份項目匯總(共 29 個項目) 2018 年 6 月份項目匯總(...
閱讀 3152·2021-11-22 12:01
閱讀 3771·2021-08-30 09:46
閱讀 787·2019-08-30 13:48
閱讀 3216·2019-08-29 16:43
閱讀 1663·2019-08-29 16:33
閱讀 1853·2019-08-29 13:44
閱讀 1416·2019-08-26 13:45
閱讀 2234·2019-08-26 11:44