如何用CSS绘制三角形和平行四边形

如果每次绘制平行四边形都要创建三个元素显然过于麻烦了,所以在这里:before和:after伪元素是个不错的选择。下面我们实现一下这样的效果:为了将三角形与矩形无缝拼接到一起,多处属性要保持一致,所以使用类似 Less, Sass, Stylus 等 CSS 预处理器来写这段代码会更容易维护,下面给出 Scss 版本的代码。
如何用CSS绘制三角形和平行四边形
最近在网上看到很多种教程教大家怎么使用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实现会动的猫脸2023-07-27
mengvlog 阅读 11 次 更新于 2025-06-20 01:21:47 我来答关注问题0
  • 第一种方法:利用border一个矩形拼接两个三角形最终制造出一个平行四边形。为什么使用border可以产生三角形呢?先来看看一张图片:看了图中的三个小图形的变化过程,你应该已经清楚了一半。其实 hack 出三角形只需要两个条件,第一,元素本身的长宽为0;其次,将不需要的部分通过 border-color 来设置隐...

  •  翡希信息咨询 用CSS实现三角形和平行四边形(前端实践)

    用CSS实现三角形和平行四边形的方法如下:三角形: 利用border属性:通过将元素的宽度和高度设置为0,并利用bordercolor属性隐藏不需要的部分,仅保留一个边作为三角形的边。通过调整borderwidth属性来控制三角形的形状和大小。平行四边形: 方法一:利用border属性和伪元素:可以通过使用:before或:after伪元...

  •  翡希信息咨询 如何用CSS绘制任意形状三角形?

    原理:利用div元素的border属性,通过调整borderwidth和bordercolor来显示三角形的边框,隐藏其他部分,从而绘制出三角形。步骤:将div的宽高设置为0,以隐藏其矩形区域。设置borderstyle为solid。调整borderwidth,使得其中三条边的宽度为0,仅保留一条边的宽度,以形成三角形的一边。设置bordercolor,仅显示...

  • 第一种方法:利用border属性。通过设置元素长宽为0,并利用border-color隐藏不需要的部分,生成三角形。借助:before和:after伪元素拼接三角形与矩形,形成平行四边形。代码使用CSS预处理器如Scss更易维护。注意三角形斜率,避免锯齿现象。第二种方法:利用transform属性。借助transform: skew(...)生成平行四边...

  •  文暄生活科普 如何用CSS绘制任意形状三角形?

    示例代码:通过设置div的border属性,调整宽高比和颜色,即可实现三角形的绘制。transform方案 CSS的仿射变换可以将矩形转换为任意形状的平行四边形。将div的两条border合并为一个直角三角形,然后通过调整transform属性实现斜边调整,实现三角形的绘制。仿射变换的组合方式多样,通过斜切和旋转等变换操作,可以...

檬味博客在线解答立即免费咨询

CSS相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部