视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
如何用CSS绘制三角形和平行四边形
2020-11-27 20:11:13 责编:小采
文档
最近在网上看到很多种教程教大家怎么使用CSS绘制图形,今天给大家总结一下如何用 如何用CSS 样式表来绘制三角形和平行四边形。感兴趣的可以深度研究一下。

第一种方法:利用border

一个矩形拼接两个三角形最终制造出一个平行四边形。为什么使用border可以产生三角形呢?先来看看一张图片:

看了图中的三个小图形的变化过程,你应该已经清楚了一半。其实 hack 出三角形只需要两个条件,第一,元素本身的长宽为0;其次,将不需要的部分通过 border-color 来设置隐藏。通过类似的方法,你还可以创造出梯形,上图中的三个图形的代码如下。(另附 CodePen 示例,http://codepen.io/jerryzou/pen/mJYJym )

#first {
 width: 20px;
 height: 20px;
 border-width: 10px;
 border-style: solid;
 border-color: red green blue brown;
}
 
#second {
 width: 0;
 height: 0;
 border-width: 10px;
 border-style: solid;
 border-color: red green blue brown;
}
 
#third {
 width: 0;
 height: 0;
 border-width: 10px;
 border-style: solid;
 border-color: red transparent transparent transparent;
}

接下来就要考虑如何拼接出一个平行四边形了。在border法中,它由三部分组成,分别是左三角形、矩形、右三角形。如果每次绘制平行四边形都要创建三个元素显然过于麻烦了,所以在这里:before和:after伪元素是个不错的选择。下面我们实现一下这样的效果:


为了将三角形与矩形无缝拼接到一起,多处属性要保持一致,所以使用类似 Less, Sass, Stylus 等 CSS 预处理器来写这段代码会更容易维护,下面给出 Scss 版本的代码。(另附 CodePen 链接,http://codepen.io/jerryzou/pen/ZGNGWZ?editors=110)

//三角形的宽高
$height: 24px;
$width: 12px;
 
//对平行四边形三部分的颜色进行赋值
@mixin parallelogram-color($color) {
 background: $color;
 &:before { border-color: transparent $color $color transparent; }
 &:after { border-color: $color transparent transparent $color; }
}
 
//单个三角形的样式
@mixin triangle() {
 content: '';
 display: block;
 width: 0;
 height: 0;
 position: absolute;
 border-style: solid;
 border-width: $height/2 $width/2;
 top: 0;
}
 
//平行四边形的样式
.para {
 display: inline-block;
 position: relative;
 padding: 0 10px;
 height: $height;
 line-height: $height;
 margin-left: $width;
 color: #fff;
 
 &:after {
 @include triangle();
 right: -$width;
 }
 
 &:before {
 @include triangle();
 left: -$width;
 }
 
 @include parallelogram-color(red);
}

需要注意的是,如果通过 $height、$width 设置的三角形斜率太小或太大都有可能造成渲染出锯齿,所以使用起来要多多测试一下不同的宽高所得到的视觉效果如何。

第二种方法:利用transform

使用transform来实现平行四边形的方法是我在逛去啊的时候看到的,效果大概是这个样子:


看到之后觉得好神奇啊,原来还可以只有平行四边形的外轮廓。(因为方法一只能创造填充效果的平行四边形)实现起来非常简单,主要是借助了transform: skew(...),下面就来看看源码吧。

<style>
.city {
 display: inline-block;
 padding: 5px 20px;
 border: 1px solid #44a5fc;
 color: #333;
 transform: skew(-20deg);
}
</style>
 
<div class="city">上海</div>

于是我们得到了这样的效果:


看到图片的你一定是这样想的:


别着急嘛,我们的确是把整个 div 进行了歪曲,导致中间的文字也是倾斜的,而这显然不是我们所要的效果。所以我们需要加一个内层元素,并对内层元素做一次逆向的歪曲,从而得到我们想要的效果:


实现代码如下,另附 CodePen 示例(http://codepen.io/jerryzou/pen/BNeNwV?editors=110)

<style>
.city {
 display: inline-block;
 padding: 5px 20px;
 border: 1px solid #44a5fc;
 color: #333;
 transform: skew(-20deg);
}
 
.city div {
 transform: skew(20deg);
}
</style>
 
<div class="city">
 <div>上海</div>
</div>

总结

第一种方法使用 border 属性 hack 出三角形,并通过对三个元素进行拼接最终实现了平行四边形;而第二种方法则通过 transform: skew 来得到平行四边形。总体来说,第二种方法相对于第一种代码量小得多,而且也很好理解。唯一的不足是无法构造像本站的分页中所使用的梯形。

希望本文对大家有所帮助,其实同理可得,正方形长方形和一些等边图形也可以用这种方法做出来。

推荐阅读:

html和css制作QQ企鹅教程

使用 CSS 3 制作长投影

css实现会动的猫脸

下载本文
显示全文
专题