我正在尝试做一个图标导航栏,其中悬停图标也悬停相同的颜色,我有图标排序,但同时我不能将它推到右边或它消失 .
主要目标是将图标放在a href的左侧,右边有大约3px的填充,因此它不会触及文本,在导航菜单上悬停图标会悬停与每个导航项目的文本相同的颜色 .
HTML
<nav class="fixed-nav-bar">
<div id="menu" class="menu">
<a class="show" href="#menu">Menu</a><a class="hide" href="#hidemenu">Menu</a>
<ul class="menu-items">
<li><div class="fa-icon-home"></div><a href="javascript:ajaxpage('pages/home.php', 'primaryContent');">HOME</a></li>
<li><a href="javascript:ajaxpage('pages/about.php', 'primaryContent');">ABOUT</a></li>
<li><a href="javascript:ajaxpage('pages/about.php', 'primaryContent');">DESIGNS</a></li>
<li><a href="javascript:ajaxpage('pages/about.php', 'primaryContent');">CONTACT</a></li>
</ul>
</div>
</nav>
CSS:
.fa-icon-home {
background-image: url('../img/home.png');
background-repeat: no-repeat;
height: 22px;
position: relative;
top: 15px;
right: 10px;
}
.fixed-nav-bar {
position: fixed;
width: 100%;
background-color: #3f3f3f;
}
.fixed-nav-bar li, .fixed-nav-bar a {
line-height: 70px;
width: 100px;
max-width: 120px;
}
.menu {
width: 90%;
max-width: 960px;
margin: 0 auto;
text-align: center;
}
.menu a, .menu a:visited {
color: #ffffff;
overflow: hidden;
font-size: 20px;
}
.menu a:hover, .menu a:target {
display: block;
color: #72BCD4;
}
.menu-items {
display: inline-block;
}
.menu-items li {
display: inline-block;
border-top: 2px solid transparent;
}
.menu-items a {
text-decoration: none;
display: block; /* New Line */
}
.menu-items li:hover {
border-top: 2px solid #72BCD4;
}
.show, .hide {
display: none;
padding-left: 15px;
background-color: transparent;
background-repeat: no-repeat;
background-position: center left;
color: #dde1e2;
}
.show {
background-image: url(../assets/down-arrow-icon.png);
}
.hide {
background-image: url(../assets/up-arrow-icon.png);
}
2 回答
我现在使用
a:before
更改了图标的应用方式 .在这里,改变了一些CSS规则,在这里你去: