前端黑魔法--纯css折角头像的实现

今天公司的设计师提交了一个文艺的需求,设计一款文艺头像,如下图



要求是在不切图的情况下(服务器端保存原图)制作折角头像,在鼠标滑过时边框颜色产生变化如下图。



细想之下这个要求简直不科学,因为图片的border怎么会有这种奇怪形状?!

但是有一个可以偷懒的办法是,整个图片背景色是固定的(如图中是白色)

以下是我的解决方案:

①最底层是头像文件,有一圈10px的红色border
②右下角罩一个三角形,使用z-index来使其浮在图片上边
③再在最上边罩一个跟底色通过色的三角形,使两个三角形大小差值(露出的那块面积)正好看起来像右下角的border

整体看起来就像下图(就像一个三明治)


那么就会存在两个问题

①使用图片来遮罩未免有些low,而且如果过后设计告诉我要调整border粗细或者遮罩面积,还得重新作图
②如何实现当鼠标滑过时头像border和中间层三角形同时变色?

首先解决第一个问题,在网上找了一圈后发现,很多花里胡哨的图片都能够通过border来绘制
如图,其实一个元素的border是这样的

这是一个50px50px的方块,它border的四个角都是以斜线的方式分割,如果把这个图形设定为0px0px,border都为100px时,是下面这样的

所以如果我想要一个右下角三角形,那么我只需不设左边上边border,如图


嘿嘿,成功!

接下来解决下一个问题,同时改变

网上搜索答案为

.main:hover .cover {}

其中main为照片的父元素,cover为中间层遮罩

.main:hover .cover {} 
.main:hover img {}

即可一个hover多个变化

p.s.:切记元素和“{}”间有个空格

接下来是实现代码

<html>

<head>
<style>
div {
box-sizing: border-box;
-moz-box-sizing: border-box;
Firefox -webkit-box-sizing: border-box;
}

    .container {
        margin-left: auto;
        margin-right: auto;
        margin-top: 100px;
    }

    .main {
        position: relative;
        width: 120px;
        height: 120px;
    }

    .cover {
        width: 0;
        height: 0;
        border: 20px solid transparent;
        border-bottom-color: red;
        border-right-color: red;
        top: -50px;
        position: absolute;
        top: 80px;
        left: 80px;
        z-index: 2;
    }

    .main:hover .cover {
        border-bottom-color: blue;
        border-right-color: blue;
    }

    .imgg {
        width: 100px;
        height: 100px;
        background-image: url(head.jpg);
        background-size: 120px;
        position: absolute;
        border: 10px solid red;
    }

    .main:hover .imgg {
        border-color: blue;
    }

    .cover-real {
        content: '';
        width: 0;
        height: 0;
        border: 13px solid transparent;
        border-bottom-color: white;
        border-right-color: white;
        top: -50px;
        position: absolute;
        top: 96px;
        left: 96px;
        z-index: 3;
    }
&lt;/style&gt;

&lt;link href=&quot;style.css&quot; rel=&quot;stylesheet&quot;&gt;

</head>

<body>
<div class="main container">
<img src="head.jpg" class="imgg">
<div class="cover"></div>
<div class="cover-real"></div>
</div>
</body>
</html>

谢谢观看