今天小編在Codepen上看到一個CSS寫的效果。一個段落的每行文字是漸變效果。對於單行文字或單字實現漸變填滿效果並不是什麼奇怪的事情,不過對於一個段落的每一行實現一個文字漸變填滿的效果。估計還是會令很多人感到好奇。如果你是其中好奇的一員,請繼續往下閱讀,一探其中之究竟!
目標效果
今天的目標效果是實現下面這樣的效果,或是說了解這種效果製作的小技巧:
#看到上面的效果,我想很多人首先會想到的就是background-clip:text、color:transparent和linear-gradient來完成。那麼事實是這樣嗎?
如何完成一個段落的每行文字漸變效果
了解CSS的同學都清楚,使用:
background-image: linear-gradient(to right, deeppink, dodgerblue); -webkit-background-clip: text; color: transparent;
就可以輕易的實現一個文本的漸變填充效果。例如下面這個範例:
來做個小實驗,如果文字不是一個單字或單行而是整個段落,效果會是如何?
效果似乎也是完美的。如果漸變效果參數換一換,漸變效果是斜角:
background-image: linear-gradient(135deg, deeppink, dodgerblue);
看看兩者的效果:
##仔細一看,兩個效果還是有差異的。先來看看同一個大小容器(本範例中的p元素,其大小是765px * 165px),對於兩種不同的漸變效果,先來看to right的填充效果: #再來看135deg的填充效果: 到這裡了,你或許就知道前面的範例有何不同?而且也知道其中的原因是什麼?如果我們想要各種漸層對於段落的每行填充效果都相同,我們該怎麼實現?在實作之前,先簡單的總結:在linear-gradient中使用to right或to left,不管是單字、單行文本或多行文本,得到的文字填滿效果都會一致。但對於其他漸變的角度參數,那麼多行文字填入中的每行效果就會有差異。 回到正題?怎麼實現多行而且不管任何填滿角度都有相同效果?實現這個效果有一個關鍵屬性:box-decoration-break。簡單的說一下,box-decoration-break屬性有兩個屬性值:slice和clone,其對應的效果如下:用於一個段落中,其效果如下: 是不是離我們的目標越來越近了。那麼把這個屬性box-decoration-break:clone用於我們的範例:background-image: linear-gradient(135deg, deeppink, dodgerblue); background-clip: text; -webkit-background-clip: text; box-decoration-break: clone; -webkit-box-decoration-break: clone; color: transparent;效果如下: 咱們來驗證一下是不是符合我們預期想要的效果: 小技巧:box-decoration-break運用於行內元素,並且配上對應的line-height,讓行與行之間有一定的間距。 回過頭來,咱們看看,使用box-decoration-break是在行內元素和區塊元素之間的區別: 是不是很完美。如果喜歡自己試試看。 相關建議:
以上是CSS Tips段落每行漸層文字效果的實作方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!