css利用 :before :after 寫小三角形執行個體分享

來源:互聯網
上載者:User
本文主要介紹了詳解css如何利用 :before :after 寫小三角形的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望能協助到大家。

之前寫的三角形一直在同一個顏色,沒有邊框的樣式。如下:

CSS代碼如下:


.tri-up{width: 0;height:0;border-left:20px solid transparent;border-right: 20px solid transparent;border-bottom: 20px solid red;  }.tri-left{width: 0;height:0;border-top:20px solid transparent;border-bottom: 20px solid transparent;border-left: 20px solid red;}.tri-right{width: 0;height:0;border-top:20px solid transparent;border-bottom: 20px solid transparent;border-right: 20px solid red;}.tri-down{width: 0;height:0;border-left:20px solid transparent;border-right: 20px solid transparent;border-top: 20px solid red; }

若要寫以下的小三角,則需要用到偽類:before :after

CSS代碼:


#demo {            margin: 100px;;            width: 100px;            height: 100px;            background-color: #fff;            position: relative;            border: 2px solid #333;        } //方框的樣式        #demo:after, #demo:before {            border: solid transparent;            content: ' ';            height: 0;            left: 100%;    //根據三角形的位置,可以隨意更改。            position: absolute;            width: 0;        }         #demo:after {            border-width: 10px;            border-left-color: #fff;            top: 20px;//根據三角的位置改變        }//此處是一個白色的三角        #demo:before {            border-width: 12px;            border-left-color: #000;            top: 18px;        }此處是一個黑色的三角//當#demo:after和#demo:before的樣式重合以後,由於top值的大小不同,就可以得到中間是白色,但是邊框的三角形。如。


<p id="demo"></p>

若要改為的樣式:

則CSS代碼如下:


#demo {            margin: 100px;;            width: 100px;            height: 100px;            background-color: #fff;            position: relative;            border: 2px solid #333;        }        #demo:after, #demo:before {            border: solid transparent;            content: ' ';            height: 0;            top: 100%;            position: absolute;            width: 0;        }        #demo:after {            border-width: 10px;            border-top-color: #fff;            left: 20px;        }        #demo:before {            border-width: 12px;            border-top-color: #000;            left: 18px;        }
相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.