使用CSS获取心形边框?

时间:2014-07-01 12:22:18

标签: html css html5 css3 css-shapes

我有这个代码,用于使用CSS创建彩色心脏(蓝色背景)和无色心脏(白色带蓝色边框):

#favourite_user {
    position: relative;
    width: 25px;
    height: 22.5px;
    margin: 30px;
    cursor:pointer;
}
#favourite_user.favourited:before,#favourite_user.favourited:after {
    background: #3498db;
}
#favourite_user.unfavourited:before,#favourite_user.unfavourited:after {
    background: #fff !important;
    border: 1px solid #3498db;
}
#favourite_user:before,
#favourite_user:after {
    position: absolute;
    content: "";
    left: 12.5px;
    top: 0;
    width: 12.5px;
    height: 20px;
    -moz-border-radius: 50px 50px 0 0;
    border-radius: 50px 50px 0 0;
    -webkit-transform: rotate(-45deg);
       -moz-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
         -o-transform: rotate(-45deg);
            transform: rotate(-45deg);
    -webkit-transform-origin: 0 100%;
       -moz-transform-origin: 0 100%;
        -ms-transform-origin: 0 100%;
         -o-transform-origin: 0 100%;
            transform-origin: 0 100%;
}
#favourite_user:after {
    left: 0;
    border-left:0px !important;
    -webkit-transform: rotate(45deg);
       -moz-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
         -o-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transform-origin: 100% 100%;
       -moz-transform-origin: 100% 100%;
        -ms-transform-origin: 100% 100%;
         -o-transform-origin: 100% 100%;
            transform-origin :100% 100%;
}

单击心脏时,我正在切换类.favourited.unfavourited,一个背景带蓝色,而另一个应该只有一个白色背景的蓝色边框。 但是我无法实现这一点,使用伪元素:before:after,这个边框的一部分效果不佳。

以下是Fiddle

任何有关该解决方案的指示都将不胜感激......提前致谢...

4 个答案:

答案 0 :(得分:3)

尝试使用字体真棒LINK

您可以使用“fa-heart-o”类而不是使用这么多代码

<强> HTML:

<i class="fa fa-heart-o"></i>

答案 1 :(得分:1)

要删除左下方的工件,您需要添加

#favourite_user:after {
    border-bottom:0px !important; /* ADDED */

Running demo

还需要!important should be avoided,因为每次浏览器引擎在规则中找到它时,它都会强制重新计算所有规则;

相反,您可以提高规则的CSS specificity,以便在应用时为其提供正确的重要性。

答案 2 :(得分:1)

您可以使用以下内容:

$('div').click(function() {
  $(this).toggleClass("active");

});
div {
  height: 200px;
  width: 200px;
  background: tomato;
  position: relative;
  margin: 100px auto;
  border-bottom: 5px solid black;
  border-right: 5px solid black;
  transform: rotate(45deg);
}
div:before,
div:after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  border-radius: 50%;
  background: tomato;
  border: 5px solid transparent;
  transform: rotate(-45deg);
  z-index: -2;
}
div:before {
  top: -5px;
  left: calc(-50% - 5px);
  border-top-color: black;
  border-left-color: black;
}
div:after {
  top: calc(-50% - 5px);
  left: -5px;
  border-top-color: black;
  border-right-color: black;
}
.active {
  border-color: blue;
  background: transparent;
}
.active:before {
  border-top-color: blue;
  border-left-color: blue;
  background: transparent;
}
.active:after {
  border-top-color: blue;
  border-right-color: blue;
  background: transparent;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div></div>

答案 3 :(得分:0)

你可以试试这个:

您也可以使用字体真棒,颜色也可以变换为字体颜色

Fontawesome:http://fortawesome.github.io/Font-Awesome/icon/heart/

Demo

#favourite_user:after {
 border:solid 1px #fff;
 position: absolute;
 content: "";
 left: 12.5px;
 top: 0;
 width: 12.5px;
 height: 20px;
 -moz-border-radius: 50px 50px 0 0;
 border-radius: 50px 50px 0 0;
 -webkit-transform: rotate(-45deg);
   -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
     -o-transform: rotate(-45deg);
        transform: rotate(-45deg);
 -webkit-transform-origin: 0 100%;
   -moz-transform-origin: 0 100%;
    -ms-transform-origin: 0 100%;
     -o-transform-origin: 0 100%;
        transform-origin: 0 100%;
}