文章封面設(shè)計一個靈活的、可維護CSS和SVG餅圖 二

我們的效果做到以下這樣似乎已經(jīng)完成了,但是一個好的代碼應(yīng)該是可以實用不同的情況,常用的情況肯定是需要滿足的 。一個高質(zhì)量的代碼 應(yīng)該是簡介 、維護性強、可訪問和多次實用。因此需要做一下完善。

首先寫入兩個div 分別為 20% 和 60%

divclass=pie90%/div
divclass=pie80%/div

然后,獲得兩個餅圖,一個20%,一個為60%。首先是通過樣式來修改 ;其次,要求代碼的優(yōu)雅、封裝、可維護性,最重要的是可訪問的前提下,我們可以總是寫一段簡短腳本來解析文本內(nèi)容,并添加內(nèi)聯(lián)樣式。

不過有個問題就是 控制餅圖顯示百分比的樣式是寫在 偽元素上 ,和你想的一樣,無法直接為偽元素寫內(nèi)聯(lián)樣式。所以需要看一下有沒有新的方法。



注:你可以在其他情況下使用類似的技術(shù),使用一個值的范圍(spectrum)而不需要復雜、重復的計算。同時,也可以通過逐步的設(shè)置值來調(diào)試動畫。查看一個更簡單、孤立的技術(shù)實例。

這個看 起來有點困難 也很少這樣使用。現(xiàn)在想之前那樣做的動畫 ,他是可以暫停的,用屬性讓他停留在一個狀態(tài) 。這個技術(shù)是可以用負動畫延遲來靜態(tài)地跳到動畫中的任何一個點,并待在那里 。弄明白了嗎?確實,負動畫延遲不僅僅是規(guī)范允許的,對于以下這些情況也是非常有用的:


一個負的延遲是有效的。就像一個‘0s’的延遲,它意味著動畫立即執(zhí)行,但是是由延遲的絕對值自動進行,就好像動畫已經(jīng)在過去的某個指定的時間開始了,因此它似乎是從中途的活躍時間開始的。

由于動畫暫停所顯示的那一幀(由我們定義的負animation-delay),就是唯一顯示的一幀。餅圖上顯示的百分比就是動畫延遲的總持續(xù)時間的百分比。例如,當前動畫持續(xù)時間為6s,我們設(shè)animation-delay為-1.2s來顯示20%。為了簡化計算,我們加上動畫持續(xù)時間為100s。注意,由于動畫是被永久性暫停,所擴大的時間是不會影響效果的。

還有一個問題:動畫是在偽元素上的,而想要的是.pie元素上設(shè)置內(nèi)聯(lián)樣式。但是,div上面沒有動畫,就需要將動畫的內(nèi)聯(lián)樣式設(shè)置在它(div)元素上,然后在偽元素上設(shè)置animation-delay: inherit;。將它們放在一起,我們對20%和60%的餅圖標記如下:

divclass=pie
style=animation-delay:-20s/div
divclass=pie
style=animation-delay:-60s/div

現(xiàn)在,我們之前為這個動畫寫的CSS代碼就多了 動畫延遲屬性 ,同時他的動畫也有所改變 :

@keyframesspin{
to{transform:rotate(.5turn);}
}
@keyframesbg{
50%{background:#655;}
}
animation:spin50slinearinfinite,
bg100sstep-endinfinite;
animation-play-state:paused;
animation-delay:inherit;

此時,我們可以將標記轉(zhuǎn)換為使用百分比作為內(nèi)容,正如我們最初的目標,并通過簡單的腳本添加動畫延遲的內(nèi)聯(lián)樣式:

document.querySelectorAll('.pie').forEach(function(pie){
			varp=parseFloat(pie.textContent);
			pie.style.animationDelay='-'+p+'s';
		});

請注意,為了更好的可用性和可訪問性,我們保留完整的文本。我們的餅圖的樣子如下圖 。我們需要隱藏文本,為保證文本的可訪問性,我們可以設(shè)置文本的color: transparent,這樣是可選擇和可打印的。進一步的美化(polish),可以讓百分比在餅圖內(nèi)居中,這樣用戶選擇它的時候,它就不會在默認的位置上。只要做一下操作:

把餅圖的height改為line-height(或者加一個line-height的CSS屬性,使它等于height,但這是毫無意義的重復的代碼,因為瀏覽器會將height的計算值設(shè)置為line-height的值)。

將偽元素的position設(shè)置為absolute,并且設(shè)置它的size,以使文本不換行,不溢出。

添加text-align: center; 使文本水平居中。

整體的代碼如圖:

今天的分享的有點多,大家學習有難度嗎? 想學習更多 或者有點難度 可以加入我們的學習群 497187010 一起交流學習 哦! 做個是基本完成了 ,但是大家別忘了美化 和調(diào)試了,比如兼容性等等 ,只要才是堪稱完美的 ,下一篇將會將svg做法 ?=^^= .。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,673評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,610評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,939評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,668評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,004評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,173評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,705評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,426評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,656評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,833評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,247評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,580評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,371評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,621評論 2 380

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