Css繪製形狀

来源:http://www.cnblogs.com/okaychen/archive/2017/07/12/7157487.html
-Advertisement-
Play Games

前言:終於我的大一生活結束了,迎來了愉快的暑假,大家都開始了各自的忙碌。一直忙著一些項目的事情,終於決定今天要更新一篇博客了,對上一階段的學習做簡單的總結。 這次我主要總結一下用Css繪製各種形狀的技巧,同時要結合before、after偽元素和定位做出一些效果。 Triangle Up(向上的三角 ...


  

  前言:終於我的大一生活結束了,迎來了愉快的暑假,大家都開始了各自的忙碌。一直忙著一些項目的事情,終於決定今天要更新一篇博客了,對上一階段的學習做簡單的總結。

  這次我主要總結一下用Css繪製各種形狀的技巧,同時要結合before、after偽元素和定位做出一些效果。

  

  Triangle Up(向上的三角形)

   

1 #triangle-up{
2    width: 0;
3     height:0;
4     border-left:50px solid transparent;
5     border-right: 50px solid transparent;
6     border-bottom: 70px solid #81cfa2;
7  }

     

  Triangle Down(向下的三角形)

  

1 #triangle-down {
2      width: 0;
3      height: 0;
4      border-left: 50px solid transparent;
5      border-right: 50px solid transparent;
6      border-top: 70px solid #81cfa2;
7  }

   

  Triangle Left(向左的三角形)

  

 

#triangle-left{
       width: 0;
       height:0;
       border-right: 70px solid #81cfa2;
       border-top: 50px solid transparent;
       border-bottom:50px solid transparent;
}

    

  Triangle TopRight(向右上的三角形)

 

#triangle-topright {
      width: 0;
      height: 0;
      border-top: 100px solid #81cfa2;
      border-left: 100px solid transparent;
}

  三角形實現比較簡單,同理可以得到一些其他的三角形,繪製三角形主要是另寬高都為0,然後利用transparent設置其他部分透明。

但是要學會在自己的項目中結合before和after偽元素以及定位做出一些組合效果,比如我正在做的Oppo社區的一個項目(我的這個做Gif的軟體有些問題)

  

  這裡我貼上導航欄處繪製三角形的代碼

 1 .search:before {
 2     border-bottom-color: #000 !important;
 3     top: -11px;
 4 }
 5 .search:after, .search:before {
 6     width: 0;
 7     height: 0;
 8     content: '';
 9     border-style: dashed dashed solid;
10     border-color: transparent transparent #fff;
11     border-width: 0 10px 10px;
12     overflow: hidden;
13     position: absolute;
14     top: -10px;
15     right: 10px;
16 }
okaychen

   但是值得註意的一點事IE6不支持transparent屬性,但是我們可以通過設置對應的透明邊框的border-style屬性為dotted或是dashed即可解決這一問題。

   接下來,我在總結幾個常用的Css繪製的形狀(結合before和after偽元素):

       Talk Bubble(聊天框)

  

 1 #talkBubble{
 2     width: 120px;
 3     height: 80px;
 4     background: #81cfa2;
 5     position: relative;
 6     border-radius: 10px;
 7     -webkit-border-radius: 10px;
 8     -moz-border-radius: 10px;
 9 }
10 #talkBubble:before{
11     content: "";
12     position: absolute;
13     right: 100%;
14     top: 26px;
15     width: 0;
16     height: 0;
17     border-top: 13px solid transparent;
18     border-right: 26px solid #81cfa2;
19     border-bottom: 13px solid transparent;
20 }

 

   Heart(心形)

 1 #Heart {
 2         position: relative;
 3         width: 100%;
 4         height: 90px;
 5     }
 6     
 7     #Heart:before,
 8     #Heart:after {
 9         content: "";
10         position: absolute;
11         left: 50px;
12         top: 0;
13         width: 50px;
14         height: 80px;
15         background: #FE4C40;
16         -moz-border-radius: 50px 50px 0 0;
17         border-radius: 50px 50px 0 0;
18         -webkit-transform: rotate(-45deg);
19         -moz-transform: rotate(-45deg);
20         transform: rotate(-45deg);
21         -webkit-transform-origin: 0 100%;
22         -moz-transform-origin: 0 100%;
23         transform-origin: 0 100%;
24     }
25     
26     #Heart:after {
27         left: 0;
28         -webkit-transform: rotate(45deg);
29         -moz-transform: rotate(45deg);
30         transform: rotate(45deg);
31         -webkit-transform-origin: 100% 100%;
32         -moz-transform-origin: 100% 100%;
33         transform-origin: 100% 100%;
34     }

    

css可以繪製很多你想不到形狀,熟練掌握一些常用的css繪製圖形的技巧可以讓你在項目中游刃有餘。

下一階段我把重點仍然放在node的學習,不急不躁:希望這個暑假我有能力總結出一篇node的博客,而不是只有在makedown上的一大片筆記。

 

     

    

 

 

 

    

 

    

 

  

  

 

 

  

  

 


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

-Advertisement-
Play Games
更多相關文章
  • "DDD理論學習系列——案例及目錄" 1.引言 聚合,最初是UML類圖中的概念,表示一種強的關聯關係,是一種整體與部分的關係,且部分能夠離開整體而獨立存在,如車和輪胎。 在DDD中,聚合也可以用來表示整體與部分的關係,但不再強調部分與整體的獨立性。聚合是將相關聯的領域對象進行顯示分組,來表達整體的概 ...
  • 回到目錄 理論閑話 之前在.netFramework平臺用的好好的,可升級到.net core平臺之後,由於不再需要二進位序列化,導致咱們的事件機制遇到了問題,之前大叔的事件一直是將處理程式序列化後進行存儲的,處理存儲的參數為事件源,一個事件源可以由多個處理程式訂閱,當事件源被髮布時,這些被序列化的 ...
  • 面試問到這個··答不出來就是沒有架構能力···這裡學習一下···面試的時候直接讓我說出26種設計模式··當時就懵逼了··我記得好像之前看的時候是23種的 還有3個是啥的··· 這裡先列出簡單的三種,工廠、抽象工廠、單例,後續在更新 工廠模式:缺點是每增加一個類型就得增加一個工具類和對象工廠類(反射可 ...
  • 擴展運算符 let zzz=[2,4,6]; console.log(zzz);//[2, 4, 6] console.log(...zzz);//2 4 6 let a=[1,2,3]; let b=[...a,4,5,6]; console.log(b);//1,2,3,4,5,6 let [a ...
  • 具體代碼如下 ...
  • 作為一名菜鳥的我,每天學點的感覺還是不錯的。今天學習閉包的過程中看到作用域與作用域鏈這兩個概念,我覺得作為一名有追求的小白,有必要詳細瞭解下。 變數的作用域 就js變數而言,有全局變數和局部變數。這裡我覺得這個按字面意思理解就行了.......下麵舉個例子 這邊有2個很有意思的地方 1.當變數不用v ...
  • if語句 三元運算符 表達式1 ? 表達式2 : 表達式3是對if……else語句的一種簡化寫法 switch語句 switch (expression) { case 常量1: 語句; break; case 常量2: 語句; break; case 常量3: 語句; break; … case ...
  • 判斷點擊的是那個tab頁 jsp: js: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...