效果如图
这个很多人可能没思路,其实就是a标签里面加个显示数量的div
<a href="index.html" class="nav-link">aaa<div class="nav-counter nav-counter-blue">4</div></a>
但是复杂的是css代码,如下
.nav-link {
position: relative;
padding: 0 14px;
line-height: 34px;
font-size: 10px;
font-weight: bold;
color: #555;
text-decoration: none;
}
.nav-link:hover {
color: #333;
text-decoration: underline;
}
.nav-counter {
position: absolute;
top: -1px;
right: 1px;
min-width: 8px;
height: 20px;
line-height: 20px;
margin-top: -11px;
padding: 0 6px;
font-weight: normal;
color: white;
text-align: center;
text-shadow: 0 1px rgba(0, 0, 0, 0.2);
background: #e23442;
border: 1px solid #911f28;
border-radius: 11px;
background-image: -webkit-linear-gradient(top, #e8616c, #dd202f);
background-image: -moz-linear-gradient(top, #e8616c, #dd202f);
background-image: -o-linear-gradient(top, #e8616c, #dd202f);
background-image: linear-gradient(to bottom, #e8616c, #dd202f);
-webkit-box-shadow: inset 0 0 1px 1px rgba(255, 255, 255, 0.1), 0 1px rgba(0, 0, 0, 0.12);
box-shadow: inset 0 0 1px 1px rgba(255, 255, 255, 0.1), 0 1px rgba(0, 0, 0, 0.12);
}
.nav-counter-green {
background: #75a940;
border: 1px solid #42582b;
background-image: -webkit-linear-gradient(top, #8ec15b, #689739);
background-image: -moz-linear-gradient(top, #8ec15b, #689739);
background-image: -o-linear-gradient(top, #8ec15b, #689739);
background-image: linear-gradient(to bottom, #8ec15b, #689739);
}
.nav-counter-blue {
background: #3b8de2;
border: 1px solid #215a96;
background-image: -webkit-linear-gradient(top, #67a7e9, #2580df);
background-image: -moz-linear-gradient(top, #67a7e9, #2580df);
background-image: -o-linear-gradient(top, #67a7e9, #2580df);
background-image: linear-gradient(to bottom, #67a7e9, #2580df);
}
html十分精简,只有一句话,但是css比较复杂,主要是a标签的position: relative,里面显示消息数量的div设成position:absolute,然后就有了重叠效果。