一直以来我都想做一个滚动文本的效果,虽然有几种方法实现,其中还有使用WebGL的方法。但我还是想使用HTML和CSS来实现这样的效果。
很多年以前,在Web上实现滚动文本的动画效果一般是采用 marquee 标签来实现,当然也有很多同学采用JavaScript来实现类似的效果。
前几天在CodePen看到有位大神使用纯CSS制作了一个3D的滚动文本效果,仔细看了一会,没想到 thenewcode.com/ 就有介绍这个案例的文章,今天将篇文章翻译出来和大家一起分享。在继续阅读下面的内容之前,先来看一下需要完成的动画效果:
译文内容从这里开始。
锐角(Acute Angles)
使用到的HTML很简单,在一个 div 的容器里,放置了两个 div 元素,而且这两个元素里放置的内容是一样的,如下所示:
<div id="marquee"> <div> <span>ONE LOVE ONE HEART</span> </div> <div aria-hidden="true"> <span>ONE LOVE ONE HEART</span> </div></div>
第二个元素是第一个元素的副本,而且在第二个 div 元素上设置一个 aria-hidden="true" 隐藏元素,所以在效果中你只能看到一个文本。
在 div#marquee 内部的 div 元素使用了3D旋转为其设置一个合适的角度,并且在其父元素中设置 perspective 的值为 0 。同时将父元素的 font-size 也设置为 0 ,主要是为了保证内部的 inline-block 元素不会产生任何的间距。
#marquee { perspective: 500px; font-size: 0;}#marquee div { display: inline-block; height: 12rem; width: 30rem; position: relative;}
如果您是第一次接触3D相关的知识,你可以点击这里了解相关方面的知识点。另外有关于如何清除 inline-block 元素之间的间距,可以阅读早先分享的一篇文章《 如何解决inline-block元素的空白间距 》。
同时使用 transform-origin 给内部元素设置稍微不同的角度,让元素变得弯曲,并且通过不同的背景颜色和文本颜色,模拟出一个光照的效果。
#marquee div:first-of-type { background: #e5233e; transform-origin: top right; transform: rotateY(-40deg); color: #fff;}#marquee div:last-of-type { background: #b31e31; transform-origin: top left; transform: rotateY(45deg); color: #f8c9d9;}
加上一些基本样式的美化,你将看到下面这样的一个效果:
文本内容放在 span 标签中,为了让容器在规则的宽度范围内能容纳一个合理数量的文本,我们需要在 div 的元素上设置 overflow 的值为 hidden ,让溢出的文本能被隐藏起来。
#marquee div { font-size: 8rem; overflow: hidden;}#marquee div span { position: absolute; width: 400%; line-height: 1.4;}
这时看到的效果是这样的:
文本滚动(Forward Crawl)
span 元素根据他们自己身不同的位置设置不同的位移:右边的文本向右移 30rem (即: div 元素可视区域宽度),左边的文本移动的距离是 div 可视区域的两倍(即,内部 div 的宽度)。为了让效果更好一些,使用 text-shadow 给文本添加一点阴影效果。
#marquee div:first-of-type span { transform: translateX(60rem); animation: leftcrawl 14s linear infinite; text-shadow: 4px 0px 4px rgba(0,0,0,0.3);}#marquee div:last-of-type span { transform: translateX(30rem); animation: rightcrawl 14s linear infinite;}
如果父元素 div 没有设置 overflow:hidden; 和文本颜色,那么初始的效果将是这样的:
两个文本都要有动画效果的。开始左边的文本需要一个延迟移动的时间,而这个时间刚好是右边文本到达转角处的时间。
@keyframes leftcrawl { to { transform: translateX(-100rem); }}@keyframes rightcrawl { to { transform: translateX(-130rem); }}
为了让文本运动是一个匀速运动效果,这里采用了 linear 的 animation-timing-function 。此时你看到效果如下:
响应式效果
当浏览器的屏幕变窄时,上面的代码做出来的效果就不太好:文本和角度变得越来越小,这样使用字幕越来越难阅读。所以当屏幕宽度小于 993px 时,将上面的3D效果换成2D效果,也就是只显示一个 div 元素:
@media all and (max-width: 993px) { #marquee { perspective: none; } #marquee div:last-of-type { opacity: 0; height: 0; } #marquee div:first-of-type { width: 80%; }}
效果如下:
你可以尝试将屏幕变窄,你将看到的效果类似下面的Gif动效:
有趣的事,使用 display:none; 隐藏元素,其动画将完全停止,这个时候当元素重新显示时会重新启动。正因为这个原因,可以采用另外一种技术来隐藏元素。即,给第二个 div 设置 opacity 和 height 的值为 0 。这样一来,如果窗口缩小或放大,动画都会一直在播放。
总结
总的来说,效果还是让我自己很满意的。当然更期待使用CSS其他的技术做出更有意思的效果。就这篇文章的效果来说,有些地方还是可以改进的,尤其是那些重复的文本内容。为了解决这样的困扰,使用JavaScript复制元素的和文本节点,可以很轻松的做到。比如文章开头的示例,我们里面就有一个输入文本的改变显示内容的效果。
本文根据 @dudleystorey 的《 Wrapping Animated 3D Marquee Text with Pure CSS 》所译,整个译文带有我们自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处: http://thenewcode.com/1096/Wrapping-Animated-3D-Marquee-Text-with-Pure-CSS 。
大漠
常用昵称“大漠”,W3CPlus创始人,目前就职于手淘。对HTML5、CSS3和Sass等前端脚本语言有非常深入的认识和丰富的实践经验,尤其专注对CSS3的研究,是国内最早研究和使用CSS3技术的一批人。CSS3、Sass和Drupal中国布道者。2014年出版《 图解CSS3:核心技术与案例实战 》。

HTML、CSS和JavaScript在Web開發中的作用分別是:1.HTML定義網頁結構,2.CSS控製網頁樣式,3.JavaScript添加動態行為。它們共同構建了現代網站的框架、美觀和交互性。

HTML的未來充滿了無限可能。 1)新功能和標準將包括更多的語義化標籤和WebComponents的普及。 2)網頁設計趨勢將繼續向響應式和無障礙設計發展。 3)性能優化將通過響應式圖片加載和延遲加載技術提升用戶體驗。

HTML、CSS和JavaScript在網頁開發中的角色分別是:HTML負責內容結構,CSS負責樣式,JavaScript負責動態行為。 1.HTML通過標籤定義網頁結構和內容,確保語義化。 2.CSS通過選擇器和屬性控製網頁樣式,使其美觀易讀。 3.JavaScript通過腳本控製網頁行為,實現動態和交互功能。

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增強WebevebDevelopment。

HTML是構建網頁結構的基石。 1.HTML定義內容結構和語義,使用、、等標籤。 2.提供語義化標記,如、、等,提升SEO效果。 3.通過標籤實現用戶交互,需注意表單驗證。 4.使用、等高級元素結合JavaScript實現動態效果。 5.常見錯誤包括標籤未閉合和屬性值未加引號,需使用驗證工具。 6.優化策略包括減少HTTP請求、壓縮HTML、使用語義化標籤等。

HTML是一種用於構建網頁的語言,通過標籤和屬性定義網頁結構和內容。 1)HTML通過標籤組織文檔結構,如、。 2)瀏覽器解析HTML構建DOM並渲染網頁。 3)HTML5的新特性如、、增強了多媒體功能。 4)常見錯誤包括標籤未閉合和屬性值未加引號。 5)優化建議包括使用語義化標籤和減少文件大小。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Dreamweaver CS6
視覺化網頁開發工具

WebStorm Mac版
好用的JavaScript開發工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

記事本++7.3.1
好用且免費的程式碼編輯器