使用CSS3製作導航條和毛玻璃效果

来源:http://www.cnblogs.com/Uncle-Keith/archive/2016/10/09/5943158.html
-Advertisement-
Play Games

導航條對於每一個Web前端攻城獅來說並不陌生,但是毛玻璃可能會相對陌生一些。簡單的說,毛玻璃其實就是讓圖片或者背景使用相應的方法進行模糊處理。這種效果對用戶來說是十分具有視覺衝擊力的。 本次分享的主題:通過CSS3來製作類似下麵的導航條和毛玻璃效果。 導航條是梯形形狀的。 背景區域的毛玻璃效果。 把 ...


導航條對於每一個Web前端攻城獅來說並不陌生,但是毛玻璃可能會相對陌生一些。簡單的說,毛玻璃其實就是讓圖片或者背景使用相應的方法進行模糊處理。這種效果對用戶來說是十分具有視覺衝擊力的。

本次分享的主題:通過CSS3來製作類似下麵的導航條和毛玻璃效果。

導航條是梯形形狀的。

背景區域的毛玻璃效果。

把導航條和毛玻璃效果在一篇文章中分享其實是有原因的。因為這兩個效果的實現離不開一個重要的思想。

用語言來描述就是:父元素設置position:relative,其偽元素(after或者before)設置 position:absolute,並且讓top,bottom,left,right都為0,偽元素占滿父元素的整個空間,最後設置z-index將背景放在父元素後邊。

具體代碼如下。

.container {
  position: relative;
}

.container::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
 z-index: -1; }

什麼意思呢?稍安勿躁,我會在接下來的兩個實戰例子中對這段代碼的意思一一道來。

 

文章結構:

1.導航條

  1.1:平行四邊形導航條

  1.2:梯形導航條

2.毛玻璃效果

3.結束語

4.參考文章

 

 

1.導航條

1.1:平行四邊形導航條

平行四邊形製作的思想:平行四邊形的製作運用了CSS3 2D 變形中的skew()傾斜屬性,因為我們只是在水平方向上傾斜,所以在使用skew()時需要將第二個參數指定為0,否則x,y軸方向都會發生傾斜,這並不是我們想要的效果。或者是使用skewX()。具體的代碼實現如下。

<div class="rascal">
        <ul>
            <li>博客園</li>
            <li>首頁</li>
            <li>新隨筆</li>
            <li>聯繫</li>
            <li>訂閱</li>
            <li>管理</li>
        </ul>
</div>
平行四邊形導航條HTML
.keith li {
  position: relative;
}
.keith li::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  z-index: -1;
  background: #2175BC;
  -moz-transform: skewX(-25deg);
  -ms-transform: skewX(-25deg);
  -webkit-transform: skewX(-25deg);
  transform: skewX(-25deg);
}
.keith li:hover::after {
  background: #2586D7;
}

上面代碼中,只顯示了部分重要部分。在設置平行四邊形的時候需要註意以下幾點:

1.給 li 元素設置relative,然後偽元素after設置absolute和LRBT四個方向的定位。原因在於我們需要讓偽元素相對與 li 元素定位,並且讓偽元素填滿整個 li 元素的空間,這樣的話給偽元素設置的背景就會鋪滿整個 li 元素 。最重要的是,在偽元素上設置skewX(),只會對偽元素進行傾斜,並不會對父元素上的文字進行傾斜。

2.設置z-index:-1。這裡如果不設置z-index值為負值的話,就看不到在 li 元素裡面的文字了,因為absolute會提高自身元素的層級,所以要讓偽元素z-index為-1,讓其的層級位居 li 元素之後。

3.使用skewX()函數讓 偽元素(不是 li 元素) 元素旋轉 25度,註意寫上屬性首碼,防止瀏覽器相容性問題。

4.將偽元素和偽類結合使用的時候,必須要註意的是先偽類,再偽元素。如果是li::after:hover 這樣設置的話是沒有任何效果的。正確的寫法:li:hover::after。

示例效果如下。

(hover狀態)

1.2:梯形導航條

梯形導航條的是實現思想:梯形導航條使用了CSS3 3D 變形中的三個屬性:perspective(),rotateX()和transform-origin。

perspective()是用於設置用戶和元素3D空間Z平面之間的距離,值越小,用戶與3D空間Z平面距離越近,視覺效果會明顯;反之,值越大,用戶與3D空間Z平面距離越遠,視覺效果越小。

ratateX()是用於3D空間中x軸的旋轉,大家可以想象一下在高中時期學的空間直角坐標系,跟那個x軸的旋轉是一樣的道理。

transform-origin是用於指定元素的旋轉中心點位置。

具體屬性的使用方法可以去查閱相關文檔,這裡就不再贅述了。具體代碼實現如下:

<div class="keith">
        <ul>
            <li>博客園</li>
            <li>首頁</li>
            <li>新隨筆</li>
            <li>聯繫</li>
            <li>訂閱</li>
            <li>管理</li>
        </ul>
</div>
梯形導航條HTML
$('.keith li').click(function(event) {
        $('.keith li').removeClass('zIndex');
        $(this).addClass('zIndex');
});
JS代碼
.keith li {
  position: relative;
}
.keith li::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
  background: #2175BC;
  -moz-transform: perspective(0.5em) rotateX(5deg);
  -ms-transform: perspective(0.5em) rotateX(5deg);
  -webkit-transform: perspective(0.5em) rotateX(5deg);
  transform: perspective(0.5em) rotateX(5deg);
  -moz-transform-origin: bottom;
  -webkit-transform-origin: bottom;
  transform-origin: bottom;
}
.keith li:hover::after {
  background: #3B9BE5;
}

上面代碼中,只顯示重要部分。註意以下幾個問題:

1.前四個問題與平行四邊形導航條的製作思路基本相同。其中,在偽元素上設置perspective()和rotateX(),只會對偽元素進行3D處理和在空間中X軸的旋轉,並不會對父元素上的文字進行任何的處理。文字還是會按照預設效果顯示。如果在父元素上設置perspective()和rotateX(),則會影響之後的所有子元素。也就是所有的子元素(包括文字)都會進行旋轉。文字被旋轉了,閱讀十分困難的。這個邏輯應該不難理解。

2.用於控制梯形是左傾斜還是右傾斜的屬性是transform-origin。梯形不傾斜:bottom。左傾斜:bottom left;右傾斜:bottom right。

示例效果如下:

(切換狀態)

(左傾斜)

(右傾斜)

2.毛玻璃效果

毛玻璃的實現思想:毛玻璃使用了CSS3中的backgroung-size,fiter濾鏡的原理。

background-size屬性用於指定背景圖片的尺寸,其中的一個參數cover是將背景圖片放大,以適合鋪滿整個容器。但是這個屬性使用的前提是需要設定一張足夠大尺寸的圖片,否則會導致背景圖片失真。

fiter濾鏡中的blur()用於將圖片進行高斯模糊處理,只接受單位值,值越大,模糊效果越明顯。

在張鑫旭老師的一篇關於毛玻璃實現的文章中(會在參考文章中給出鏈接),給出了毛玻璃實現的效果,可是有一些小問題:如果在背景圖片上加上文字,blur()會將文字一起模糊掉,這樣的話會用戶體驗不太好。當然,在不需要文字的背景圖片下,張鑫旭老師的方案還是很棒的。

以下給出具體代碼:

<div class="rascal">
        My Name is Uncle-Keith!
</div>
毛玻璃HTML
body {
  background: url("../images/family-one.jpg") no-repeat center center fixed;
  -moz-background-size: cover;
  -o-background-size: cover;
  -webkit-background-size: cover;
  background-size: cover;
}

.rascal {
  position: relative;
  background: rgba(255, 255, 255, 0.3);
  overflow: hidden;
}
.rascal::after {
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: url("../images/family-one.jpg") no-repeat center center fixed;
  -moz-background-size: cover;
  -o-background-size: cover;
  -webkit-background-size: cover;
  background-size: cover;
  -webkit-filter: blur(20px);
  filter: blur(20px);
  margin: -30px;
}

上面代碼中,需要註意幾個問題:

1.同樣這裡也是使用父元素relative,偽元素absolute的方法,並且設置了TBLR和z-index。使用這種方法的關鍵之處在於我們是對偽元素進行了blur()處理,這樣並不會影響到父元素中的文字效果。

2.需要給背景圖片添加background-size屬性,這個是為了讓圖片自適應整個屏幕的寬度。另外,這個屬性需要添加兩次。一是在body元素上,一是在偽元素上。在偽元素上添加的原因是我們要讓blur()處理模糊的圖片與背景圖片相同。如果在偽元素中給background設置inherit的話,只會繼承父容器rascal的背景,而rascal容器是一個白色背景的容器,這樣就與我們的效果不相同了。下圖是在偽元素中使用background:inherit;的毛玻璃效果。

這並不是我們想要的毛玻璃效果。所以偽元素上background的設置應該與背景圖片是相同的。

3.在為偽元素設置正確的background之後,我們要使用margin負值模糊邊緣消退的問題。

可以看到,毛玻璃中的blur()效果有點過猶不及了,一圈模糊效果超出了容器,給父元素設置overflow:hidden,可以將超出的部分剪切掉。最終的示例效果如下。

最終效果看起來就很自然了。

 

3.結束語

三個實例中,有一個共同的思想:將CSS3的傾斜,透視,旋轉和濾鏡效果都放在偽元素中,並且給父元素設置relative,偽元素設置absolute,讓偽元素的寬度和高度撐滿父元素的整個區域,最後設置偽元素的z-index為負值。這樣做的好處就是不會影響父容器中的文字。

具體的代碼如下:

.container {
  position: relative;
}

.container::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
 z-index: -1;
}

 

4.參考文章

張鑫旭老師談毛玻璃實現

阮一峰老師談高斯模糊原理

 

 

完。感謝大家的閱讀。

轉載請註明出處:http://www.cnblogs.com/Uncle-Keith/p/5943158.html

 

 

 





您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天給同學寫一個相冊照片滑鼠浮動顯示細節的效果,遇到了閃動的bug,也順利解決,就寫下來跟大家分享。 我使用的是‘標簽:hover + 標簽’的形式,如果使用jquery的mouseover、mouseout等事件,也可以參考此方法,原理一樣。 分析:圖片使用,然後使用div+span寫入滑鼠浮動要 ...
  • 今天第一次遇到const定義的變數,查閱了相關資料整理了這篇文章。主要內容是:js中三種定義變數的方式const, var, let的區別。 1.const定義的變數不可以修改,而且必須初始化。 2.var定義的變數可以修改,如果不初始化會輸出undefined,不會報錯。 3.let是塊級作用域, ...
  • 本文講述 padding / border 的設置後是否對 width 有影響,width 等於 auto 與 100% 的區別 CSS 框模型 (Box Model) 規定了元素框處理元素內容、內邊距、邊框 和 外邊距 的方式。 概述 那麼 css 屬性中width = ?呢 在標準的w3c的規定 ...
  • 用 或者 來監控文件的改變,當文件改變時,就自動刷新瀏覽器。 用 來實時編譯scss文件。 用 來非同步執行npm script命令。 先安裝上述的node工具 npm install browser sync 一、首先新建npm的 一般有如下的結構和選項 { "name": "about", "ve ...
  • 1.介紹 http-server 是一個簡單的零配置命令行HTTP伺服器, 基於 nodeJs. 如果你不想重覆的寫 nodeJs 的 web-server.js, 則可以使用這個. 2.安裝 安裝成功如下: 3.使用 在站點目錄下開啟命令行輸入 http-server 運行結果如圖: 在瀏覽器輸入 ...
  • 最近需要做一個zTree+EasyUi的許可權管理系統,以前有過接觸,在做這一塊時,用到了ztree,樹來載入咱們的菜單欄,後臺獲取登錄用戶信息的許可權列表,轉換成json對象來載入到咱們的樹當中,代碼如下: 你會發現人家早就想到了這一點,來實現這個效果,那麼, 我們就可以運用到自己的ztree當中了, ...
  • 一、簡介 這個例子是根據一個真實app的一個頁面的需求來實現的demo,通過動態add ui的方式,動態bind數據構建一個完整的課程表示例。示例並不完善,但是可以給大家一個啟發。 二、效果圖 三、相關下載 https://github.com/do-project/code4do/tree/mas ...
  • JavaScript 中一些概念理解 :clientX、clientY、offsetX、offsetY、screenX、screenY ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...