一張圖教會CSS3倒影

来源:http://www.cnblogs.com/jiaoyu121/archive/2017/06/25/7078403.html
-Advertisement-
Play Games

分享 示例圖片 示例圖片 在CSS3之前,想要實現示例圖片這樣的一個倒影效果一般只能通過處理圖片的方式,而CSS3問世之後,想要實現這樣的效果變得非常簡單,只需一個CSS3屬性就可以輕鬆實現了。 這就是今天所要提到的box-reflect屬性。 咱們先看看W3C給出的box-reflect語法: b ...


分享
示例圖片

在CSS3之前,想要實現示例圖片這樣的一個倒影效果一般只能通過處理圖片的方式,而CSS3問世之後,想要實現這樣的效果變得非常簡單,只需一個CSS3屬性就可以輕鬆實現了。

這就是今天所要提到的box-reflect屬性。

咱們先看看W3C給出的box-reflect語法:

box-reflect:none | <direction> <offset>? <mask-box-image>? (?代表可預設,也就是後倆屬性可有可無)
<direction> = above | below | left | right (分別代表:上 | 下 | 左 | 右)
<offset> = <length> | <percentage>(分別代表:固定值 | 百分比)
<mask-box-image> = none | <url> | <linear-gradient> | <radial-gradient>| <repeating-linear-gradient> | <repeating-radial-gradient>(分別代表:沒有遮罩圖片 | 遮罩圖片路徑 | 線性漸變 | 徑向漸變 | 重覆線性漸變 | 重覆徑向漸變)
預設值:none

box-reflect可給兩種屬性值,一種是none,為預設值,也就是沒有任何倒影效果,另一種才是我們今天所要講的,它可以同時賦予三個屬性值,它們依次代表倒影方向、元素與倒影之間的距離以及加在倒影上的遮罩圖像,其中後兩個屬性值可以預設,但如果<mask-box-image>存在,則<offset>必填。

說了那麼多乾巴巴的解釋,還是聯繫一下示例應該更好理解些吧。

我們現在來一步步地實現文章開頭示例圖片的投影效果:

①只給一個屬性值below。

<!--HTML代碼-->
< img class="img" src="imgs/cat.jpg" />
/*CSS代碼*/
.img{ -webkit-box-reflect: below; box-reflect: below;}

實現效果:

②再加個5px的間距。

/*CSS代碼*/
.img{ -webkit-box-reflect: below 5px; box-reflect: below 5px;}

實現效果:

③最後加個圖片遮罩吧。

/*CSS代碼*/
.img{ -webkit-box-reflect: below 5px -webkit-linear-gradient(transparent 60%,rgba(0,0,0,.3));
box-reflect: below 5px linear-gradient(transparent 60%,rgba(0,0,0,.3));}

這裡的圖片遮罩沒有用圖片,而是用了CSS3中的linear-gradient屬性值,它就是用於線性漸變,具體用法這裡就不提了,可以直接看這裡(http://www.w3cplus.com/content/css3-gradient ),寫得很詳細。

實現效果:

這就是文章開頭示例圖片的最終效果。

接下來,再說說徑向漸變創建圖片遮罩和直接使用圖片遮罩。

徑向漸變的話其實跟線性漸變類似,只需要你掌握CSS3中基本的徑向漸變方法,給個簡單示例吧:

/*CSS代碼*/
.img{ -webkit-box-reflect: left 0 -webkit-radial-gradient(#000 30%,transparent);
 box-reflect: left 0 radial-gradient(#000 30%,transparent);}

實現效果:

效果很棒!好像貓咪真的在照鏡子一樣~~

那如果直接使用圖片遮罩呢?比如說我用這樣一張圖片作為遮罩:

/*CSS代碼*/
.img{ -webkit-box-reflect: right 0 url(imgs/mask.png); box-reflect: right 0 url(imgs/mask.png);}

實現效果:


mask.png

可以看出,遮罩圖片會完全拉伸填充倒影圖片,並且效果是完全透明部分不會顯示出來(其實CSS3漸變圖片遮罩原理也跟這個是一樣的)。

需要註意的是,以上講的所有效果不僅僅可以用在圖片上,用在其他元素上也是完全可以的,比如說文字。

相容性: box-reflect雖然看起來效果很不錯,但是遺憾的是,目前只有webkit內核瀏覽器相容,不過移動端基本已經沒有任何問題啦~~

學習過程中遇到什麼問題或者想獲取學習資源的話,歡迎加入學習交流群
343599877,我們一起學前端!


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

-Advertisement-
Play Games
更多相關文章
  • 題目鏈接 Problem Description In mathematics, the four color theorem, or the four color map theorem, states that, given any separation of a plane into cont ...
  • SELECT版FTP:使用SELECT或SELECTORS模塊實現併發簡單版FTP允許多用戶併發上傳下載文件 必須使用select or selectors模塊支持多併發,禁止使用多線程或多進程 REDMAE 1 #!usr/bin/env python 2 #-*-coding:utf-8-*- ...
  • 問題分析: pip命令不是在python解釋器中執行的,而是在windows的命令行下執行。pip是在Python\Scripts目錄下的,打開cmd,cd到該目錄,然後輸入pip install tornado即可正確安裝 。 ...
  • 今天和搜索部門一起做了一下MQ的遷移,順便交流一下業務和技術。發現現在90後小伙都挺不錯。我是指能力和探究心。我家男孩,不招女婿。 在前面的文章中也提到,我們有媒資庫(樂視視頻音頻本身內容)和全網作品庫(外部視頻音頻內容),數據量級都在千萬級。我們UV,PV,CV,VV都是保密的。所以作為一個合格的 ...
  • 根據以前的命名服務,從新構建了下服務框架; 結構模式;c-center-s; 1.服務端: 服務端啟動,講自己的IP,埠註冊到註冊中心節點(master),然後註冊自己的處理類(需要繼承對應介面); 同時需要設置服務類型(是否是主從服務,如果是主從服務還需要設置自己是否是master); 如果不是 ...
  • 1、搭建項目框架 npm初始化項目 npm init -y //按預設配置初始化項目 安裝需要的第三方庫 npm install bootstrap angular angular-route --save 新建一個index.html頁面 引用 這三個依賴庫 新建兩個文件夾coming_soon ...
  • Vue Admin 是一個基於 Vue 2.0 & Bulma 0.3 的後臺管理面板(管理系統),相當於是 Vue 版本的 Bootstrap,提供了一組通用的後臺界面 UI 和組件,其中還有豐富的圖表組件,開箱即用。趕緊來體驗一下吧。 ...
  • 分享 Vue 官網教程上關於 v-model 的講解不是十分的詳細,寫這篇文章的目的就是詳細的剖析一下, 並介紹 Vue 2.2 v-model改進的地方,然後穿插的再說點 Vue 的小知識。 在 Vue 中,有許多方法和 Angular 相似,這主要是因為 Angular 是 Vue 早期開發的靈 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...