首頁  >  文章  >  web前端  >  CSS怎麼做梯形的標籤頁

CSS怎麼做梯形的標籤頁

php中世界最好的语言
php中世界最好的语言原創
2018-03-21 13:15:141980瀏覽

這次帶給大家CSS怎麼做出梯形的標籤頁,CSS做出梯形標籤頁的注意事項有哪些,下面就是實戰案例,一起來看一下。

在web設計中,梯形標籤頁是很常見的一種形式,但是梯形又是一種很難實現的樣式,很多開發者會直接用梯形背景圖片來產生效果,但是採用背​​景圖片的方式產生了額外的http請求,並不是一種非常理想的方式,這裡筆者為大家帶來一種直接用css來實現梯形效果的方法。
 

以一個簡單的p為例:

<p>这是一个梯形</p>
.p{
    position: relative;
    display: inline-block;
    padding: .5em 1em .35em;
    color: white;
}
.p::before{
    content: ''; /*用伪元素来生成一个矩形*/
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: #58a;
    transform: scaleY(1.3) perspective(.5em) rotateX(5deg);
    transform-origin: bottom;
}

如果我們直接對元素結點進行3D變形,那麼元素內的內容也會產生變形,這是不理想的效果,所以這裡利用偽元素,將變形效果作用到偽元素上,就可以實現理想的效果。在這裡,變形的時候,我們固定住了底部,它的高度是會改變的,所以透過scaleY(1.3)來補足它在高度上的縮水。讀者可以去掉scaleY(1.3)和transform-origin來比較查看效果,這裡筆者將兩個結果都呈現出來:

CSS怎麼做梯形的標籤頁CSS怎麼做梯形的標籤頁

這是沒有scaleY和transform-origin產生的結果

這是上述程式碼產生的樣式結果

既然一個梯形標籤產生了,那我們就可以進一步產生多個標籤頁,這裡筆者為大家帶來一個簡單的範例。

<nav>
    <a>Home</a>
    <a>Projects</a>
    <a>About</a>
</nav>
nav>a{
    position: relative;
    display: inline-block;
    padding: .3em 1em 0;
}
nav>a::before{
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: #ccc;
    background-image: linear-gradient(hsla(0,0%,100%,.6),hsla(0,0%,100%,0));
    border: 1px solid rgba(0,0,0,.4);
    border-bottom: none;
    border-radius: .5em .5em 0 0;
    transform: perspective(.5em) rotateX(5deg);
    transform-origin: bottom;
}

產生的效果圖是這樣的:

CSS怎麼做梯形的標籤頁

讀者可以改變transform-origin的屬性為:left,right,bottom left, left right等看不同的效果,這裡筆者為大家展示幾種效果:

CSS怎麼做梯形的標籤頁CSS怎麼做梯形的標籤頁CSS怎麼做梯形的標籤頁CSS怎麼做梯形的標籤頁

##相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:
css3的pointer-events使用詳解


完全利用CSS實作元素居中


focus-within的使用詳解


#CSS3做出無縫輪播廣告

#######

以上是CSS怎麼做梯形的標籤頁的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn