如下图:左侧三角形
css代码如下:
CSS Code复制内容到剪贴板
#talkbubble{margin-left:30px;width:120px;height:80px;background:red;position:relative;-moz-border-radius:10px;-webkit-border-radius:10px;border-radius:10px;}#talkbubble:before{content:"";position:absolute;rightright:100%;top:26px;width:0;height:0;border-top:13pxsolidtransparent;border-right:26pxsolidred;border-bottom:13pxsolidtransparent;}其实,本案例的精华就是三角形的绘制,那么如何绘制三角形呢?我在这里总结一下!
上三角形,上三角形,顶部是尖的,所以用border-left,border-right,和border-bottom可以实现,给bottom一个颜色,其他设置为transparent
CSS Code复制内容到剪贴板
#triangle-up{width:0;height:0;border-left:50pxsolidtransparent;border-right:50pxsolidtransparent;border-bottom:100pxsolidred;}同理,大家可以判断一下如下代码分别是什么样的三角形!
CSS Code复制内容到剪贴板
#triangle-down{width:0;height:0;border-left:50pxsolidtransparent;border-right:50pxsolidtransparent;border-top:100pxsolidred;}#triangle-left{width:0;height:0;border-top:50pxsolidtransparent;border-right:100pxsolidred;border-bottom:50pxsolidtransparent;}#triangle-rightright{width:0;height:0;border-top:50pxsolidtransparent;border-left:100pxsolidred;border-bottom:50pxsolidtransparent;}#triangle-topleft{width:0;height:0;border-top:100pxsolidred;border-right:100pxsolidtransparent;}#triangle-topright{width:0;height:0;border-top:100pxsolidred;border-left:100pxsolidtransparent;}#triangle-bottomleft{width:0;height:0;border-bottom:100pxsolidred;border-right:100pxsolidtransparent;}#triangle-bottomright{width:0;height:0;border-bottom:100pxsolidred;border-left:100pxsolidtransparent;}判断出上面代码分别代表什么三角形吗?没错,我的命名是根据三角形的方向来的。大家可以试一下。三角形会写了,那么对话框就迎刃而解了! 不管是左侧的,还是上面的,只要改变一下before伪类的定位,就可以实现了。
当然,三角形的写法是很基础的。你也可以用css绘制出五角星、六角星、多边形、爱心等等。当然有些符号是不常用的,用的最多的还是三角形。