【CSS進階】偽元素的妙用2 - 多列均勻佈局及title屬性效果

来源:http://www.cnblogs.com/coco1s/archive/2016/07/13/5667853.html
-Advertisement-
Play Games

最近無論是工作還是自我學習提升都很忙,面對長篇大論的博文總是心有餘而力不足,但又不斷的接觸學習到零碎的但是很有意義的知識點,很想分享給大家,所以本篇可能會很短。 本篇接我另一篇講述 CSS 偽元素的文章: 【CSS進階】偽元素的妙用–單標簽之美,看完本文覺得有意思的可以再去看看上一篇,分享了一些偽元 ...


最近無論是工作還是自我學習提升都很忙,面對長篇大論的博文總是心有餘而力不足,但又不斷的接觸學習到零碎的但是很有意義的知識點,很想分享給大家,所以本篇可能會很短。

本篇接我另一篇講述 CSS 偽元素的文章: 【CSS進階】偽元素的妙用–單標簽之美,看完本文覺得有意思的可以再去看看上一篇,分享了一些偽元素的妙用。

正文從這裡開始:

 

哪些標簽不支持偽元素?

我也是才知道這個姿勢。為了不誤導讀者,就趕緊補充一下。

偽元素雖然強大,但是還是有一些特定的標簽是不支持偽元素 before 和 after 的。

諸如 <img\> 、 <input\>、 <iframe\>,這幾個標簽是不支持類似 img::before 這樣使用。

究其原因,要想要標簽支持偽元素,需要這個元素是要可以插入內容的,也就是說這個元素要是一個容器。而 input,img,iframe 等元素都不能包含其他元素,所以不能通過偽元素插入內容。

 

純CSS實現title屬性hover效果

我們都知道,在 HTML 標簽中有這樣一個屬性 – title,該屬性規定關於元素的額外信息,就是我們可以往 title 裡面填入一段文字,滑鼠移到元素上時就會顯示這段文本。

像是這樣 <element title="value" >。效果如下:

;

但是這個 hover 框有兩個小問題:

  • 響應太慢,通常滑鼠 hover 上去要隔 1s 左右才會出現這個 title 框

  • 框體結構無法自定義,彈出框的樣式無法自定義

嗯,通常要解決上面的方法,或者說我們需要一個滑鼠 hover 上去的時候彈出一個提示層的效果都不會採用 title 屬性,而是配合使用 JS 模擬一個彈出層。

這裡有一個純 CSS 的方案可以解決這個場景,運用了偽元素,先上 Demo:

滑鼠 hover 一下文字,發現彈出層響應十分迅速(因為就是 CSS hover,沒有延遲)。並且這裡的彈出層的樣式也可以完全自定義,沒有用到 JS 代碼,並且查看 HTML 代碼可以看到不需要多餘的標簽。

怎麼實現的呢?主要是運用了偽元素的 content 屬性, content 通常是用於在偽元素中插入內容的。而其中有一句語法 content: attr(value) 類似這樣,可以讀取對應 HTML 標簽的 value 屬性。也就是:

  1. 假設一個 HTML 標簽定義為: <div data-msg="ABC">

  2. 那麼該 div 對應的偽類如果設置了 content:attr(data-msg) ,就可以讀取到 data-msg 的值,相當於content:"ABC"

而且框體由於是偽類生成的,所以我們可以自定義它的樣式及位置,運用這個效果,我們應用在可以在許多無法正常把信息展示完的地方。

 

借用偽元素實現多列均勻佈局

我們經常需要實現多列均勻佈局,能夠自適應各種情況,如下:

在移動端我們可以使用 flex 佈局,但是在 PC 端如果要相容 IE6+ ,通常都需要一些額外的標簽控制最後一個元素或者配合 JS 進行運算。

我們知道,有個 text-align:justify 可以實現兩端對齊文本效果,一開始我猜測使用它可以實現:

試了一下是不行的,並沒有實現所謂的兩端對齊,查找原因,在 W3C找到這樣一段解釋:

最後一個水平對齊屬性是 justify,它會帶來自己的一些問題。CSS 中沒有說明如何處理連字元,因為不同的語言有不同的連字元規則。規範沒有嘗試去調和這樣一些很可能不完備的規則,而是乾脆不提這個問題。

額,我看完上面一大段解釋還是沒明白上面意思,再繼續查證,才找到原因:

雖然 text-align:justify 屬性是全相容的,但是要使用它實現兩端對齊,需要註意在模塊之間添加[空格/換行符/製表符]才能起作用。

也就是說每一個 <i>1</i> 間隙,至少需要有一個空格或者換行或者製表符才行。

我嘗試給每一塊中間添加一個換行符,發現還是不行:

再尋找原因,是出在最後一個元素上面,然後我找到了 text-align-last 這個屬性,text-align-last 屬性規定如何對齊文本的最後一行,並且 text-align-last 屬性只有在 text-align 屬性設置為 “justify” 時才起作用。

嘗試給容器添加 text-align-last:justify,發現終於可以了,多列均勻佈局:

但是一看相容性,慘不忍睹,只有 IE 和 最新的 chrome 支持 text-align-last 屬性,也就是說,如果你不是在使用 IE 或者 最新版的 chrome 觀看本文,上面這個 codePen 例子還是沒有均勻分佈。

好,鋪墊了這麼久,終於可以引出本文的主角偽元素了,上面說了要使用 text-align:justify 實現多列佈局,要配合 text-align-last ,但是它的相容性又不好,真的沒辦法了麽,其實還是有的,使用偽元素,可以完美實現:

通過給偽元素 :after 設置 inline-block ,配合容器的 text-align: justify 就可以輕鬆實現多列均勻佈局了。配合幾句 hack 代碼,可以實現相容到 IE6+ ,最重要的是代碼不長,很好理解。

最後這種方法也是最近才學習到的,參考了這篇文章,非常值得一讀:

 

本文主要就是多介紹了偽元素的兩種實用方法,更多偽元素的妙用可以戳
CSS3奇思妙想,採用單標簽完成各種圖案 – Demo (請用 Chrome 瀏覽器打開,非常值得一看)。

我另一篇講述 CSS 偽元素的文章: 【CSS進階】偽元素的妙用–單標簽之美,看完本文覺得有意思的可以再去看看上一篇。

也希望覺得不錯的同學順手在我的 Github 點個 star : CSS3奇思妙想 。

希望這篇文章對大家有所幫助,尤其是在對問題解決的思維層面上。

到此本文結束,如果還有什麼疑問或者建議,可以多多交流,原創文章,文筆有限,才疏學淺,文中若有不正之處,萬望告知。


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

-Advertisement-
Play Games
更多相關文章
  • python 發郵件的功能 ...
  • c++中:的作用:初始化列表,後面的表達式用於初始化它的成員變數,或者基類的成員變數 。 c++中::的作用: 雙冒號 :: 操作符被稱為域操作符(scope operator),含義和用法如下:1.在類外部聲明成員函數。void Point::Area(){};2.調用全局函數;表示引用成員函數變 ...
  • ...
  • 創建FileUtil.php文件,內容及調用方式如下: <?php /** * 操縱文件類 * * 例子: * FileUtil::createDir('a/1/2/3'); 測試建立文件夾 建一個a/1/2/3文件夾 * FileUtil::createFile('b/1/2/3'); 測試建立文 ...
  • C++中的const關鍵字的用法非常靈活,而使用const將大大改善程式的健壯性,本人根據各方面查到的資料進行總結如下,期望對朋友們有所幫助。 Const 是C++中常用的類型修飾符,常類型是指使用類型修飾符const說明的類型,常類型的變數或對象的值是不能被更新的。 No. 作用 說明 參考代碼 ...
  • 項目結構: 這是一個maven項目,主函數在Client類裡面 當運行程式的後,控制台情況: 當我們刷新了test.html文件後,用瀏覽器打開效果: 說一下這個過程的設計思路: 1.讀取excel文件 2.利用velocity模板工具把讀取的內容渲染到html裡面 整個過程就兩個步驟,是不是非常簡 ...
  • 在生產環境實現配置文件和war包 的分離,為方便在必要的時候進行一定的更改,可以避免修改包,但是需要重啟 最初為這樣的選擇配置,單不知為何未生效,修改為配置2配置方法,但不靈活,待跟進。配置1: 配置2: <!-- 環境配置和war包分離 以外部配置為準--> 註:order 值越小,優先順序越高 ...
  • 什麼是MVP?在“MVP初探”里就有講過了,就是一種UI的架構模式。 簡單的描述一下Unity和Exception Handling Application Block: Unity是一個輕量級的可擴展的依賴註入(DI)容器,支持構造函數,屬性和方法調用註入。構建一個成功應用程式的關鍵是實現非常鬆散 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...