【CSS】平行四边形

作者: 德育处主任 | 来源:发表于2018-01-22 21:39 被阅读54次
微信订阅号:rabbit_svip


先上效果图

image.png

平行四边形可以用做导航栏部分。

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

CSS代码

transform: skewX(-45deg);

上面的代码表示:沿X轴倾斜 -45 度。

但如果只用上面的代码作用在元素上,会导致其内容也发生倾斜变形,会影响阅读。

image.png



解决方法1:嵌套元素

用嵌套元素的方法,对内容再应用一次反向的 skew() 变形,从而抵消容器对内容产生的变形效果。

HTML代码

<a href="http://suo.im/1yaTY3">
    <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 href="http://suo.im/1yaTY3">
    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】八边形

相关文章

  • css导航样式平行四边形和css的X样式

    一、css导航样式平行四边形 效果图如下: 代码: css如下: .menu { margin: 0 aut...

  • 强大的CSS:实现平行四边形布局效果

    如何实现下图所示的平行四边形布局效果? 一、skewX的局限 一提到平行四边形,条件反射般的就会想起CSS tra...

  • 【CSS】平行四边形

    先上效果图 平行四边形可以用做导航栏部分。 原理:利用transform属性拉伸矩形。 CSS代码 transfo...

  • 【CSS】八边形

    做八边形效果,也是像【CSS】平行四边形 这个笔记里讲的那样,用transform属性,旋转内容。 HTML代码 ...

  • 002 四边形的一些基本性质

    平行四边形 两组对边分别平行的四边形叫做平行四边形。(平行四边形的对边相等。平行四边形的对角相等。) 平行四边形的...

  • 阅读CSS Secrets(九)

    平行四边形 这里需要用到css3的transform属性 使用skewY来制作跟向Y轴倾斜的四边形 多个div然后...

  • 平行四边形的推倒

    平行四边形:平行四边形的底相当于长方形的长,平行四边形的高相当于长方形的宽。 如下图: (1)有些平行四边形无法计...

  • 平行四边形的面积探索

    第1章:什么是平行四边形 如果要探究平行四边形的面积,要先知道什么是平行四边形,那么平行四边形首先是一个四边形,...

  • iOS绘制带圆角的平行四边形

    一、平行四边形 2、带渐变色的平行四边形

  • 学生不得不知的《平行四边形和梯形》

    知识点1:平行四边形的基本特征 1.两组对边分别平行的四边形叫作平行四边形。 2.平行四边形的基本特征:平行四边形...

网友评论

    本文标题:【CSS】平行四边形

    本文链接:https://www.haomeiwen.com/subject/wkbraxtx.html