css 实现一个带尖角的正方形

实现图示的效果涉及到的知识主要有两点:一个是before、after伪元素,一个是border

1、before 和 after 都是css中的伪元素,通过给定一个属性content给元素添加新的内容

before:用来在元素前插入新内容。

after:用来在元素后面插入新内容。

(1)before 给元素添加内容实例:

<p>我</p>

如果给这个p元素设置一个before:

p:before{ content:"爱你"; }

这个p就变成了:我爱你,content属性的值就添加到了p元素内容的前面。
(2)after 给元素添加内容实例:
<p>我</p>

p:after{   content:"20岁了"; }

这个p就会变成:我20岁了

2、利用伪元素设置css样式,如题目中的尖角,题目只给出一个div,只能弄出左边的带边框正方形,右边的尖角怎么来的呢?那就可以靠这个伪元素来完成了。

思路解析:

(1)先把正方形画出来

#demo{
  width:100px;
  height:100px;
  background-color:#fff;
  border: 2px #000 solid;
  position: relative;
 }

(2)通过before或者after变出一个尖角出来。放到正方形右上角去。

1)首先,我们复习一下border属性。

border-width:
thin(细边框) medium (中等边框)thick(细边框) 10px(像素值)只有当边框样式不是 none 时才起作用
border-style:
dotted (点状)solid(实线) double(双线) dashed(虚线);
border-color:设置不同的颜色

2)boder实例:

一个边长为20px的正方形,设置border为20px,可得效果:,html代码如下:
<html>
    <head>
        <title></title>
        <style type="text/css">
        #demo{
                 width:20px;
                  height:20px;
                 background-color:#fff;
                  border: 20px #000 solid;

              }
        </style>
    </head>
    <body>
    <div id="demo">

    </div>
    </body>
</html>

我们可以根据border-left,border-right,border-top,border-bottom手动设置四个边框为不同颜色,css代码如下

#demo
{
     width:20px;
      height:20px;
     background-color:#fff;
      border-left: 20px pink solid;
      border-right:20px red solid;
      border-top:20px green solid;
      border-bottom:20px blue solid;
 }

将div宽度设置为0,则可见四个彩色小三角形。css代码修改如下:

#demo
{ 
     width:0px;  
      height:0px; 
     background-color:#fff;  
      border-left: 20px pink solid;
      border-right:20px red solid;
      border-top:20px green solid;
      border-bottom:20px blue solid;
 }

3)拓展思考,如果将三边边框透明,是不是就可以实现一个小三角形?

如果只设置左边框,不设置其他三个边框。

#demo
{ 
    width:0px;  
    height:0px; 
    background-color:#fff;  
    border-left: 20px pink solid;
    /*border-right:20px red solid;
    border-top:20px green solid;
    border-bottom:20px blue solid;*/
 }

实验结果:页面空白。原因:因为如果只设置左边框,而这个div的高度又为0,那这个左边框是不会向上下两端扩展。

只不设置左边框,其余三边均设置。

#demo
{ 
    width:0px;  
    height:0px; 
    background-color:#fff;  
    border-left: 20px pink solid;
    /*border-right:20px red solid;*/
    border-top:20px green  solid;
    border-bottom:20px blue solid;
 }

实验结果:。分析:未设置左边框,所以上下边框只向右边扩展。

只设置左边框,不设置右边框,上下边框设置透明。

#demo
{ 
    width:0px;  
    height:0px; 
    background-color:#fff;  
    border-left: 20px pink solid;
    /*border-right:20px red solid;*/
    border-top:20px transparent solid;
    border-bottom:20px transparent solid;
 }

实验结果: 分析,上下边框设置透明,左边框向上下扩展。

实现一个小三角,先设置四边透明,再设置颜色,代码更简洁:

#demo
{ 
    width:0px;  
    height:0px;  
    border: 20px transparent solid; 
    border-left-color: #000;
}

(3)把三角形放到正方形右侧。

    分析:正方形是缺了一段,我们可以让三角形颜色为白色覆盖掉正方形的边框,另外再用一个黑色的比白色三角形大一点的三角形放在白三角形下面,这样就只漏出了三角形的两条边,所以这里就要用到before和after。

   1)因为before和after插入的三角形是放在指定的位置的,所以它们的position都设置为绝对定位absolute,那么div就要设置成相对定位relative。

     这里首先回顾一下定位的区别:position(static(默认)|relative|fixed|absolute)

    static:按照浏览器正常的文档流摆放 top left right bottom
    relative:相对于static本来位置。即默认的位置
    absolute 相对于父类元素定位,父元素的position必须是relative或者是absolute,如果不是,则继续往上查找父元素,如果一直找不到,则最后相对于body定位。
    fixed:相对于body元素

  2)首先绘出黑三角形

#demo:before {
  content: ' ';
  width: 0;
  height: 0;
  border: solid transparent;
  left: 100%;
  top: 18px;
  position: absolute;
  border-width: 12px;
  border-left-color: #000;
}

实验结果:

3)绘制白色三角形

#demo:after
 {
    content: ' ';
    width: 0;
    height: 0;
    border: solid transparent;
    left: 100%;
    top: 20px;
    position: absolute;
    border-width: 10px;
    border-left-color: #fff;
 }

实验结果:

(4)整理CSS重叠属性,简化代码,最终完整页面HTML代码如下:

<html>
    <head>
        <title>demo</title>
        <style type="text/css">
            #demo
            {
                width: 100px;
                height: 100px;
                background-color: #fff;
                position: relative;
                border: 2px solid #000;
            }

            #demo:before, #demo:after
            {
                 border: solid transparent;
                content: ' ';
                height: 0px;
                width: 0px;
                left: 100%;
                position: absolute;
            }
            #demo:before {
                border-width: 12px;
                border-left-color: #000;
                top: 18px;

            }
             #demo:after
            {
                top: 20px;
                border-width: 10px;
                border-left-color: #fff;
            }

        </style>
    </head>
    <body>
    <div id="demo">

    </div>
    </body>
</html>

读书破万卷,下笔如有神.

评论

返回顶部