用css写三角形

作者: 蚊子简叔 | 来源:发表于2016-10-10 01:30 被阅读0次

在布局中,经常遇到一些三角形形状的按钮:

常用三角形形状

其实用html+css就能实现,很简单,代码如下:

第一种方法

html代码:

<!-- 向上 -->
<div class="top_triangle"></div>
<!-- 向下 -->
<div class="bottom_triangle"></div>
<!-- 向左 -->
<div class="left_triangle"></div>
<!-- 向右 -->
<div class="right_triangle"></div>

css代码

/*向上*/
        .top_triangle{
            width:0;
            height:0;
            border-bottom:30px solid green;
            border-right:30px solid transparent;
            border-left:30px solid transparent; 
        }
        /*向下*/
        .bottom_triangle{
            width:0;
            height:0;
            border-top:30px solid black;
            border-right:30px solid transparent;
            border-left:30px solid transparent;
        }
        /*向右*/
        .left_triangle{
            width:0;
            height:0;
            border-top:30px solid transparent;
            border-left:30px solid yellow;
            border-bottom:30px solid transparent;
        }
        /*向左*/
        .right_triangle{
            width:0;
            height:0;
            border-top:30px solid transparent;
            border-right:30px solid red;
            border-bottom:30px solid transparent;
        }
第二种方法

以上代码便是实现上下左右方向三角形的代码;然而其实不难发现,其实它们之间有个共同点,都是由border中的top、right、bottom、left实现的,因此我们还有一种写法,通过实现设置一个div的border,让其隐藏掉,再给其中一个方向颜色,该方向的三角形就能显现出来,比如实现向上方向的三角形的css代码:

 .top_triangle{
            width:0;
            height:0;
            //将其先隐藏掉,再显示。
            border:30px solid transparent;
            border-bottom:30px solid green; 
        }

其它方向的就相类似,就不一一举例了。

一点tips

如果认真尝试敲过这个代码的读者或许会发现,以第一种方法的例子比方,都给border设置了三个方向的值,好奇的人会想,只设置两个行或者一个行吗?敲敲就知道啦~

实践中告诉我,设置一个或者两个但设置相反方向上的border值的都不会显示出来,可以试试;但是如果两个中,不同方向上的两个值是会显示出来的,至于是什么形状,就看你选的方向了。实践出真知!

实现的基本理解(方便记)

图片中最左方的正方形css代码如下:

.all_triangle{
            width:0;
            height:0;
            border-top:30px solid black;
            border-left:30px solid yellow;
            border-right:30px solid red;
            border-bottom:30px solid green;
        }

加上在代码中出现最多的transparent(我理解隐藏掉),就不难理解,其实也就是将一个盒模型中的padding+content,用width+height都设置为零干掉,然后给让border隆重登场,设置相应的值,当然这些值都是必须的,然后呢,将要显现出来的显示,该隐藏的就隐藏,第一种方法中干脆就省略了一个(也只能是一个),至于大小颜色位置就随你设置了 。

延伸

css3中的border-radius,有个图案如下


应用蛮多的

其实这个的实现用border也行。代码如下:

.eatFace{
            width:0;
            height:0;
            border:30px solid red;
            border-radius:50%;
            border-right:30px solid transparent;
        }

至于原理,如果大家读懂了三角形的,这个不难理解。

最后,感谢读到最后的读者,纯属学习中的分享,望多多指教,寻求共同进步!

相关文章

  • css 实现三角形箭头

    插入DOM 使用伪类 参考:用纯CSS实现的箭头CSS画三角形原理css整理 -- 右箭头,上下箭头,三角形 这个...

  • css制作三角形

    1. 用css的border属性制作三角形

  • 用css3写直角三角形、一角是圆角的三角形

    用css3写直角三角形比较常见,可以参考:https://blog.csdn.net/qq_34382449/ar...

  • css实现三角形

    今天学到的两种方式可以实现三角形,简单写一下 方法一: html代码: 我是三角形 css代码如下:用伪元素实现一...

  • 用css写三角形

    在布局中,经常遇到一些三角形形状的按钮: 其实用html+css就能实现,很简单,代码如下: 第一种方法 html...

  • css绘制三角形和对号

    CSS绘制三角形 div css 效果 CSS绘制对号 div css 效果

  • 三角形气泡框

    用CSS写三角形,首先要理解的是border不是矩形,而是梯形。 但是如果把border的宽度改成30px呢? 改...

  • 笔试题整理(五)

    百度外卖 1、用css和html实现一个三角形详见css面试题(二)2、用apply()模拟bind()函数《ja...

  • css三角形

    用 CSS3 做一个三角形? 用伪类实现一个上三角?

  • CSS 绘制三角形

    昨天写页面,遇到了个三角形样式,第一反应图片切出来就行了,但又想,为啥不能直接用css写呢?于是琢磨了一下。 1 ...

网友评论

    本文标题:用css写三角形

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