先来看一下效果:http://1.huizit1.applinzi.com/CSS/transform_3D/img_3D.html
布局结构:
<div class="container"> <img src="/static/imghwm/default1.png" data-src="../Img/1.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/2.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/3.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/4.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/5.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/6.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/7.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/8.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/9.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > <img src="/static/imghwm/default1.png" data-src="../Img/10.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" > </div>
CSS3中新增了translate-style和perspective属性,要让图片有3D的效果就要添加这两个属性,具体的解释这里不再赘述,可以看这篇文章来理解:http://www.zhangxinxu.com/wordpress/2012/09/css3-3d-transform-perspective-animate-transition/
给container添加translate-style为preserve-3d,添加perspective: 2000px;
这里一共10张图片,为了让10张图片围成一个圆,需要添加position属性为absolute,设置宽度相同,居中,这时所有图片都重合在了一起。每张图片绕Y轴旋转36*i(i:0->9)度(rotateY),然后每张图片在Z轴方向移动相同的距离(translateZ),这个距离能保证图片不重合在一起就行。这时图片就围成了一个环状,并且是有3D效果的。然后给container添加动画属性让其绕Y轴不停旋转(rotateY),这时动画就出现了。
注意:给图片添加的属性transform: rotateY(0deg) translateZ(350px);rotateY和translateZ的位置不能交换,因为先旋转后移动和先移动后旋转的效果是不一样的。
这里我给container添加了背景颜色来参考图片的相对位置和旋转轴。
如果要用鼠标点击来切换图片的话,只需要每次点击之后container的旋转角度加36度就可以。
贴上代码:
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>img_3D</title> 6 </head> 7 <style type="text/css"> 8 @keyframes an1{ 9 0%{10 transform: rotateY(0deg) ;11 }12 50%{13 transform: rotateY(180deg) ;14 }15 100%{16 transform: rotateY(360deg) ;17 }18 }19 .container{20 width: 900px;21 height: 400px;22 background: rgba(255,0,0,0.5);23 /*opacity: 0.3;*/24 25 margin: 200px auto;26 perspective: 2000px;27 transform-style: preserve-3d;28 animation: an1 10s linear 0s infinite;29 }30 .container img{31 width: 200px;32 height: auto;33 margin: auto;34 top: 0;35 bottom: 0;36 left: 0;37 right: 0;38 position: absolute;39 }40 .container img:nth-child(1){41 transform: rotateY(0deg) translateZ(350px);42 }43 .container img:nth-child(2){44 transform: rotateY(36deg) translateZ(350px);45 }46 .container img:nth-child(3){47 transform: rotateY(72deg) translateZ(350px);48 }49 .container img:nth-child(4){50 transform: rotateY(108deg) translateZ(350px);51 }52 .container img:nth-child(5){53 transform: rotateY(144deg) translateZ(350px);54 }55 .container img:nth-child(6){56 transform: rotateY(180deg) translateZ(350px);57 }58 .container img:nth-child(7){59 transform: rotateY(216deg) translateZ(350px);60 }61 .container img:nth-child(8){62 transform: rotateY(252deg) translateZ(350px);63 }64 .container img:nth-child(9){65 transform: rotateY(288deg) translateZ(350px);66 }67 .container img:nth-child(10){68 transform: rotateY(324deg) translateZ(350px);69 }70 </style>71 <body>72 <div class="container">73 <img src="/static/imghwm/default1.png" data-src="../Img/1.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >74 <img src="/static/imghwm/default1.png" data-src="../Img/2.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >75 <img src="/static/imghwm/default1.png" data-src="../Img/3.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >76 <img src="/static/imghwm/default1.png" data-src="../Img/4.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >77 <img src="/static/imghwm/default1.png" data-src="../Img/5.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >78 <img src="/static/imghwm/default1.png" data-src="../Img/6.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >79 <img src="/static/imghwm/default1.png" data-src="../Img/7.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >80 <img src="/static/imghwm/default1.png" data-src="../Img/8.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >81 <img src="/static/imghwm/default1.png" data-src="../Img/9.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >82 <img src="/static/imghwm/default1.png" data-src="../Img/10.jpg" class="lazy" alt="CSS3实现3D效果的图片墙_html/css_WEB-ITnose" >83 </div>84 </body>85 </html>

HTML代碼可以通過在線驗證器、集成工具和自動化流程來確保其清潔度。 1)使用W3CMarkupValidationService在線驗證HTML代碼。 2)在VisualStudioCode中安裝並配置HTMLHint擴展進行實時驗證。 3)利用HTMLTidy在構建流程中自動驗證和清理HTML文件。

HTML、CSS和JavaScript是構建現代網頁的核心技術:1.HTML定義網頁結構,2.CSS負責網頁外觀,3.JavaScript提供網頁動態和交互性,它們共同作用,打造出用戶體驗良好的網站。

HTML的功能是定義網頁的結構和內容,其目的在於提供一種標準化的方式來展示信息。 1)HTML通過標籤和屬性組織網頁的各個部分,如標題和段落。 2)它支持內容與表現分離,提升維護效率。 3)HTML具有可擴展性,允許自定義標籤增強SEO。

HTML的未來趨勢是語義化和Web組件,CSS的未來趨勢是CSS-in-JS和CSSHoudini,JavaScript的未來趨勢是WebAssembly和Serverless。 1.HTML的語義化提高可訪問性和SEO效果,Web組件提升開發效率但需注意瀏覽器兼容性。 2.CSS-in-JS增強樣式管理靈活性但可能增大文件體積,CSSHoudini允許直接操作CSS渲染。 3.WebAssembly優化瀏覽器應用性能但學習曲線陡,Serverless簡化開發但需優化冷啟動問題。

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。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

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

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)