用纯css写出三角形

1、新建一个元素,随便什么元素,不过我习惯性的会用块元素来做。如果行内元素就display:block它。
<div
class="triangle"></div>
2、把它的宽高设置为height:0px;
width:0px;

3、设置边框border属性,用来实现三角形。
首先要了解border具体是怎么样的,我写了一个这样的样式:
border:50px
solid #000; border-color:#f00 #000 #f0f #00f;

在FF下面显示效果如下:

出现4个三角形合并成一个正方形。到这里就很清晰了,只要把想要的保留,其它的设置为透明就可以达到三角形的效果,那么:
border:50px
solid #000; border-color:#f00 transparent transparent
transparent;

在FF就可以看到一个红色三角形如下:

但是IE呢,尤其是坑爹的IE6会怎样? 如图:

这是因为它不支持transparent,所以不会透明,那么可以这样:
border:50px solid
#000; border-color:#f00 transparent transparent transparent; border-style:solid
dashed dashed
dashed;
在你想它透明的地方对应的把border-style设置为dashed,IE6就可以达到跟FF一样的效果了。
那这样也就只是实现了4个方向的三角形,那如果要直角对着45斜线方向的呢?那么可以用两个正方向的三角形并在一起来实现,如下图:

代码:
border:50px solid #000; border-color:#f00 #000
transparent transparent; border-style:solid solid dashed
dashed;
只要把颜色统一,就形成一个45斜线方向三角形,而在IE6却会是这样一种显示:

这是因为IE6有个行高撑开了,把行高设置为0就跟FF一样了:line-height:0px;
最终演示:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>用CSS画三角形</title>
<style type="text/css">
*{ margin:0px; padding:0px;}
.triangle{ display:block; height:0px; width:0px; border:50px solid #000; border-color:#f00 transparent transparent transparent; border-style:solid solid dashed dashed; line-height:0px;}
</style>
</head>
<body>
<div class="triangle"></div>
</body>
</html>

事实上,我也是在写三角形才得知,当然上面的文字可想而知是百度的,下面是我用到的

.triangle_up, .triangle_down_red, .triangle_down_gray{
    position:absolute; left:0; top:0; height:0; width:0; overflow:hidden; border-left:4px solid transparent; border-right:4px solid transparent;_border-left:4px solid #fff; _border-right:4px solid #fff;
}

.triangle_up{ border-bottom:4px solid #ca0309;}

.triangle_down_red{ border-top:4px solid #ca0309; }

.triangle_down_gray{ border-top:4px solid #c1c1c1;}

<div class="triangle_up"></div>
<div class="triangle_down_red"></div>
<div class="triangle_down_gray"></div>
时间: 2024-10-16 15:18:08

用纯css写出三角形的相关文章

纯css写出爱心版加载效果,等待加载也是一种享受

现在互联网时代网站何其多,各有各得风格,但是什么样的风格能留住用户的停留观看呢?就从加载来说,很多加载效果都是同一种风格可能用户经常逛网站早已经习惯,要是你的加载时间比其他网站时间长,效果还是一样的,可能就会关掉你的网站去其他网站观看,但是如果你的加载效果别具一格,有特点,可能用户看你加载效果的时候你的网站就打开了,这样用户也就不会立刻关掉你的网站. html代码: <div class="flex-container"> <div class="unit&

【转】纯CSS写三角形-border法[晋级篇01]

(1)有边框的三角形 我们来写下带边框的三角形. 如果是一个正方形,我们写边时,会用到border,但我们这里讨论的三角形本身就是border,不可能再给border添加border属性,所以我们需要用到其他办法. 最容易想到的,是叠加层.思路是将两个三角形叠加在一起,外层三角形稍大一些,颜色设置成边框所需的颜色:内层三角形绝对定位在里面.整体就能形成带边框三角形的假象. 这里就涉及到一个绝对定位的问题,上.下.左.右四种方向的三角形相对于父级定位是不同的.首先我们来看下,当定位都为0(left

纯CSS写三角形-border法[基础篇]

纯CSS写三角形-border法[基础篇] 注意:所有知识点将不考虑IE6 ( ̄▽ ̄") 在制作如上图所示的三角形时,我们基本采用PNG或GIF图片来实现,这种形式在编写代码时较容易掌握,所以得到普遍制作者的认可.但涉及到后期优化维护的话,就需要不断的修改图片,在图形编辑器和代码编辑器之间来回切换,这无疑是加大了工作量.所以,如果单纯利用CSS来写的话,不但可以减少网站零碎图片的数量.减少了加载图片的时间,而且在修改时不用再重新切图,减少工作量. CSS3出现以后,“方形旋转45度”制作三角形的

纯CSS写三角形-border法[晋级篇01]

纯CSS写三角形-border法[晋级篇01] 注意:所有知识点将不考虑IE6 ( ̄▽ ̄") (1)有边框的三角形 在上一篇完成简单的三角形border法后,我们来写下带边框的三角形. 如果是一个正方形,我们写边时,会用到border,但我们这里讨论的三角形本身就是border,不可能再给border添加border属性,所以我们需要用到其他办法. 最容易想到的,是叠加层.思路是将两个三角形叠加在一起,外层三角形稍大一些,颜色设置成边框所需的颜色:内层三角形绝对定位在里面.整体就能形成带边框三角

重新整理:纯CSS写三角形

整理一下几年前写的知识点,关于如何用纯CSS写三角形. 方法1:利用CSS3旋转正方形 知识点: transform:rotate(45deg) 兼容性:FF/Chrome/IE9+ html: <div class="imgbox1"> <img src="images/200x300.jpg" alt="" /> <p>内容文字内容文字内容文字内容文字</p> </div> CSS:

如何用css画出三角形

看到有面试题里会有问到如何用css画出三角形 众所周知好多图形都可以拆分成三角形,所以说会了画三角形就可以画出很多有意思的形状 画出三角形的原理是调整border(边框)的四个方向的宽度,线条样式以及颜色. 如果你将宽度调的足够大,改变不同方向的颜色,你就可以发现盒模型的border是四个梯形一样的线条. 这个时候如果将盒模型内部的height,width调为0px,则三角形就形成了. 1 border:100px solid transparent //边框100px,实线,透明颜色,下面三行

纯css写带小三角对话框

在实际样式中经常会遇到要写类似对话框的样式,而这种样式往往会有一个小三角,如下所示: 那么如何用css写出来呢,其实很简单,先让父元素相对定位,然后运用css的伪类before或after.就可以写个三角形,如果想要带边框的三角形,则可以两个重叠使用.代码如下: <div class="box2"> 纯css写带小三角对话框 </div> .box2{ float:left; position:relative; width:200px; height:100p

无聊,纯css写了个评分鼠标移入的效果

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta h

纯CSS弹出层,城市切换效果

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>纯CSS弹出层效果</title> <meta http-equiv="Content-Type" content="text