搜尋
首頁web前端css教學如何借助CSS創建一個旋轉木馬?

如何借助CSS創建一個旋轉木馬?

旋轉木馬在網路上非常有名。 網路旋轉木馬是一種優雅的方式,可以將相似的內容組織到一個觸覺的地方,同時保留寶貴的網站空間。它們用於展示照片、提供產品,並吸引新訪客的興趣。但是它們的效果如何?有很多反對旋轉木馬的論點,以及研究使用旋轉木馬來提高性能。但是旋轉木馬如何影響網站的可用性?

在本文中,我們將討論輪播圖的基礎知識以及如何使用HTML和CSS建立輪播圖。

什麼是輪播圖?

輪播圖是一種幻燈片展示,可以顯示一系列旋轉的橫幅/圖片。輪播圖通常出現在網站的首頁。它可以改善您的網站的外觀。 Web輪播圖,也被稱為滑桿、畫廊和幻燈片,可讓您在一個動態的「滑動」區塊中顯示文字、圖形、圖像甚至影片。它們是將內容和概念分組的優秀設計選擇,可以在特定內容之間建立視覺連結。

Web輪播圖因此非常適合在電子商務網站上推廣相關產品,在設計作品集中展示特色項目,甚至在房地產網站上循環播放家居內外照片。然而,它們並不總是最佳選擇。

許多設計師批評它們會減慢載入時間並破壞設計的流暢性。然而,與任何設計相關的事物一樣,當正確地完成時,網頁輪播可以以更容易遍歷的方式分割內容。

如何製作一個網頁輪播圖?

在這裡,我們將看到如何製作一個簡單的網頁輪播圖,而不使用像Bootstrap這樣的框架。

需要遵循的步驟

  • 使用HTML建立走馬燈的基本結構,其中包含圖像。在下面的範例中,我們為走馬燈添加了4張圖像。此外,還有4個按鈕,點擊按鈕將顯示對應的圖像。

  • 首先,建立一個作為容器的 div 元素,其中包含 標題內容

  • 現在,content div 包含兩個部分- carousel content(包含在整個過渡過程中保持固定的文字部分)和slideshow# (包含移動部分,即4張圖片和按鈕)。

  • 使用CSS來為輪播圖像和按鈕添加樣式。保持幻燈片的位置為相對定位。

  • 使用CSS動畫使輪播中的影像平滑過渡。

Example

的中文翻譯為:

範例

以下範例示範了一個包含4個影像和控制影像顯示的按鈕的輪播。這些影像以固定時間間隔進行過渡顯示。

<!DOCTYPE html>
<html>
<head>
   <title> Web Carousel </title>
   <style>
      * {
         box-sizing: border-box;
         margin: 10px;
         padding: 3px;
      }
      body {
         background-color: rgb(195, 225, 235);
      }
      .box {
         width: 600px;
         height: 400px;
         display: flex;
         flex-direction: column;
         justify-content: center;
         align-items: center;
         margin: auto;
      }
      .title {
         padding: 10px 0 10px 0;
         position: absolute;
         top: 10px;
      }
      .content {
         position: relative;
         top: 10%;
      }
      .carousel-content {
         position: absolute;
         top: 50%;
         left: 45%;
         transform: translate(-40%, -40%);
         text-align: center;
         z-index: 50;
      }
      .carousel-title {
         font-size: 48px;
         color: black;
         margin-bottom: 1rem;
         font-family: Times New Roman;
      }
      .slideshow {
         position: relative;
         height: 100%;
         overflow: hidden;
      }
      .wrapper {
         display: flex;
         width: 400%;
         height: 100%;
         top: 10%;
         border-radius: 30%;
         position: relative;
         animation: motion 20s infinite;
      }
      .slide {
         width: 80%;
         height: 200%;
         border-radius: 30%;
      }
      .img {
         width: 100%;
         height: 100%;
         object-fit: cover;
      }
      @keyframes motion {
         0% {left: 0;}
         10% {left: 0;}
         15% {left: -100%;}
         25% {left: -100%;}
         30% {left: -200%;}
         40% {left: -200%;}
         45% {left: -300%;}
         55% {left: -300%;}
         60% {left: -200%;}
         70% {left: -200%;}
         75% {left: -100%;}
         85% {left: -100%;}
         90% {left: 0%;}
      }
      .button {
         position: absolute;
         bottom: 3%;
         left: 50%;
         width: 1.3rem;
         height: 1.3rem;
         background-color: red;
         border-radius: 50%;
         border: 0.2rem solid #d38800;
         outline: none;
         cursor: pointer;
         transform: translateX(-50%);
         z-index: 70;
      }
      .button-1 {
         left: 20%;
      }
      .button-2 {
         left: 25%;
      }
      .button-3 {
         left: 30%;
      }
      .button-4 {
         left: 35%;
      }
      .button-1:focus~.wrapper {
         animation: none;
         left: 0%;
      }
      .button-2:focus~.wrapper {
         animation: none;
         left: -100%;
      }
      .button-3:focus~.wrapper {
         animation: none;
         left: -200%;
      }
      .button-4:focus~.wrapper {
         animation: none;
         left: -300%;
      }
      .button:focus {
         background-color: black;
      }
   </style>
</head>
<body>
   <div class= "box">
      <h1 id="Responsive-Carousel-using-CSS"> Responsive Carousel using CSS </h1>
      <div class= "content">
         <div class= "carousel-content">
         </div>
         <div class= "slideshow">
            <button class= "button button-1"> </button>
            <button class= "button button-2"> </button>
            <button class= "button button-3"> </button>
            <button class= "button button-4"> </button>
            <div class= "wrapper">
               <div class= "slide">
                  <img  src="/static/imghwm/default1.png"  data-src="https://wallpapercave.com/wp/wp2782600.jpg?x-oss-process=image/resize,p_40"  class="lazy"  class= "img" src= "https://www.tutorialspoint.com/static/images/simply-easy-learning.jpg" alt="如何借助CSS創建一個旋轉木馬?" >
               </div>
               <div class= "slide">
                  <img  src="/static/imghwm/default1.png"  data-src="https://wallpapercave.com/wp/wp2782600.jpg?x-oss-process=image/resize,p_40"  class="lazy"  class= "img" alt="如何借助CSS創建一個旋轉木馬?" >
               </div>
               <div class= "slide">
                  <img  src="/static/imghwm/default1.png"  data-src="https://i.insider.com/5fd90e7ef773c90019ff1293?   style="max-width:90%"  class="lazy"  class= "img" alt="如何借助CSS創建一個旋轉木馬?" >
               </div>
               <div class= "slide">
                  <img  src="/static/imghwm/default1.png"  data-src="https://wallpaperaccess.com/full/1164582.jpg?x-oss-process=image/resize,p_40"  class="lazy"  class= "img" alt="如何借助CSS創建一個旋轉木馬?" >
               </div>
            </div>
         </div>
      </div>
   </div>
</body>
</html>

CSS Transform 屬性

要修改視覺格式模型所使用的座標空間,請使用CSS中的transform屬性。透過這樣做,可以對元素應用傾斜、旋轉和平移等效果。

文法

transform: none| transform-functions| initial| inherit;

價值觀

  • translate(x, y) − 此函數定義了沿著X和Y座標的平移。

  • translate3d(x, y, z) − 此函數提供了沿著X、Y和Z座標軸的平移。

  • initial − 將元素設為其預設值。

  • inherit − 它繼承父元素的值。

CSS動畫

CSS的animation屬性允許我們在一定的時間間隔內更改元素的各種樣式屬性,從而為它添加動畫效果。

動畫的一些特性如下:

  • Animation-name - 它允許我們指定動畫的名稱,後續由@keyframes使用該名稱來指定要執行該動畫的CSS規則。

  • 動畫持續時間 - 設定動畫的持續時間

  • 動畫時間函數 - 表示動畫的速度曲線,即動畫從一組CSS自訂屬性變化到另一組所使用的時間間隔。

  • Animation-delay – 在給定的時間間隔內為起始值設定延遲

@keyframes用於指定在給定的時間段內動畫中需要執行的程式碼。這是透過在動畫期間為某些特定的「幀」聲明CSS屬性來實現的,百分比從0%(動畫的開始)到100%(動畫的結束)。

以上是如何借助CSS創建一個旋轉木馬?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:tutorialspoint。如有侵權,請聯絡admin@php.cn刪除
將框陰影添加到WordPress塊和元素將框陰影添加到WordPress塊和元素Mar 09, 2025 pm 12:53 PM

CSS盒子陰影和輪廓屬性獲得了主題。讓我們查看一些在真實主題中起作用的示例,以及我們必須將這些樣式應用於WordPress塊和元素的選項。

使用GraphQL緩存使用GraphQL緩存Mar 19, 2025 am 09:36 AM

如果您最近開始使用GraphQL或審查了其優點和缺點,那麼您毫無疑問聽到了諸如“ GraphQl不支持緩存”或

使您的第一個自定義苗條過渡使您的第一個自定義苗條過渡Mar 15, 2025 am 11:08 AM

Svelte Transition API提供了一種使組件輸入或離開文檔(包括自定義Svelte Transitions)時動畫組件的方法。

優雅且酷的自定義CSS捲軸:展示櫃優雅且酷的自定義CSS捲軸:展示櫃Mar 10, 2025 am 11:37 AM

在本文中,我們將深入研究滾動條。我知道,這聽起來並不魅力,但請相信我,一個精心設計的頁面是齊頭並進的

展示,不要說展示,不要說Mar 16, 2025 am 11:49 AM

您花多少時間為網站設計內容演示文稿?當您撰寫新的博客文章或創建新頁面時,您是在考慮

使用Redwood.js和Fauna構建以太坊應用使用Redwood.js和Fauna構建以太坊應用Mar 28, 2025 am 09:18 AM

隨著最近比特幣價格超過20k美元的攀升,最近打破了3萬美元,我認為值得深入研究創建以太坊

NPM命令是什麼?NPM命令是什麼?Mar 15, 2025 am 11:36 AM

NPM命令為您運行各種任務,無論是一次性或連續運行的過程,例如啟動服務器或編譯代碼。

讓我們使用(x,x,x,x)來談論特殊性讓我們使用(x,x,x,x)來談論特殊性Mar 24, 2025 am 10:37 AM

前幾天我只是和埃里克·邁耶(Eric Meyer)聊天,我想起了我成長時代的埃里克·邁耶(Eric Meyer)的故事。我寫了一篇有關CSS特異性的博客文章,以及

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Safe Exam Browser

Safe Exam Browser

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

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具