我有这个代码,用于使用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
任何有关该解决方案的指示都将不胜感激......提前致谢...
答案 0 :(得分:3)
答案 1 :(得分:1)
要删除左下方的工件,您需要添加
#favourite_user:after {
border-bottom:0px !important; /* ADDED */
还需要!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/
#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%;
}