【CSS】平行四邊形

微信訂閱號:rabbit_svip



先上效果圖

image.png

平行四邊形可以用做導航欄部分。

原理:利用transform屬性拉伸矩形。

CSS代碼

transform: skewX(-45deg);

上面的代碼表示:沿X軸傾斜 -45 度。

但如果只用上面的代碼作用在元素上,會導致其內容也發生傾斜變形,會影響閱讀。

image.png




解決方法1:嵌套元素

用嵌套元素的方法,對內容再應用一次反向的 skew() 變形,從而抵消容器對內容產生的變形效果。

HTML代碼

<a >
    <div>HOME</div>
</a>

CSS代碼

a {
    width: 100px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #58a;
    text-decoration: none;
    color: #fff;
    transform: skewX(-45deg);
}
div {
    transform: skewX(45deg);
}

效果如圖所示

image.png


這種方法在表現上很不錯,不過在邏輯上比較直接粗暴。

我們理解的HTML,更應該作用在框架的搭建上,而不是樣式的表現上。如果結構層的更變是不允許的,或者希望嚴格保持結構層的純凈度,這種方法不是好方法。

注意:像上面的例子中,如果想把布局的樣式用在a(內聯元素)里,記得把它的display設成inline-block或block等值,否則變形不會生效。

這里我設置成flex,為了方便把內容居中。




解決方法二:偽元素

把所有樣式應用到偽元素上,然后再對偽元素進行變形。
內容層(文字部分)只做顏色、字號等設置。

HTML代碼

<a >
    HOME
</a>

CSS代碼

a::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: #58a;
    transform: skewX(-45deg);
}
a {
    width: 100px;
    height: 40px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    text-decoration: none;
}
image.png

也能得到同樣的效果。這種方法不會污染HTML結構層。

這種方法為偽元素保持了良好的靈活性,可以自動繼承其宿主元素的尺寸。

首先給宿主元素應用 position: relative 樣式,并為偽元素設置 position: absolute,然后再把所有偏移量設置為0,以便讓它在水平和垂直方向上都被拉伸至宿主元素的尺寸(top: 0; right: 0; bottom: 0; left: 0;)。

此時,用偽元素生成的方塊是重疊在內容之上的,一旦給它設置背景,就會遮住內容。所以要為偽元素設置 z-index: -1 。這樣它的堆疊層次就會被推到宿主元素之后。



HTML與CSS 目錄:HTML與CSS

下一篇:【CSS】八邊形

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,805評論 1 92
  • 本文主要是起筆記的作用,內容來自慕課網. 認識CSS樣式 CSS全稱為“層疊樣式表 (Cascading Styl...
    0o凍僵的企鵝o0閱讀 2,663評論 0 30
  • 選擇qi:是表達式 標簽選擇器 類選擇器 屬性選擇器 繼承屬性: color,font,text-align,li...
    wzhiq896閱讀 1,805評論 0 2
  • 喜歡小貓的活潑靈動,可愛的五官、敏捷的身手、毛茸茸的觸感,畫面里微微抬起的小爪子正想撲捉落在粉紅毛線團子上的蝴蝶,...
    希波克林閱讀 1,422評論 14 30
  • 轉瞬間一周時間過去了,參加微商公社特種兵學習已經一個星期了,在這一周的時間里,我學到了很多我以前都沒有接觸過的東西...
    何放微商公社商學院閱讀 192評論 0 0