为什么这个锚标签不占用其父 div 的可用空间的 100%?

Sam*_*les 2 html css anchor

我的理解使我相信,将 a<a>display:block;CSS 属性放在 a<div>中应该会导致整个 div“成为”链接(即我在 div 中悬停的任何地方,它都被视为链接,因为链接占用 100 % 高度和宽度)。

这种行为在下面的例子中似乎不起作用。如果您更愿意inspect element使用实时代码浏览自己,您可以查看网站@:http : //shayla.phasesolutions.ca/。有关我所描述的问题,请参阅页面顶部的导航。

HTML:

    <header>
        <div class="logo"><a href="#"></a></div>
        <div class="nav-homepage"><a href="#"></a></div>
        <div class="nav-webdesign"><a href="#"></a></div>
        <div class="nav-graphicdesign"><a href="#"></a></div>
        <div class="nav-miscartwork"><a href="#"></a></div>
        <div class="nav-aboutme"><a href="#"></a></div>
        <div class="nav-contactme"><a href="#"></a></div>
    </header>
Run Code Online (Sandbox Code Playgroud)

CSS:

header {
    .site-section;
    height: 125px;

    div {
        float: left;
        position: relative;
        top: 10px;

        a {
            display: block;
        }
    }

    div:first-child {
        position: relative;
        top: 0px;
    }
}
.nav-aboutme, .nav-contactme, .nav-graphicdesign, .nav-homepage, .nav-miscartwork, .nav-webdesign, .shadow, .homepage-nav-aboutme, .homepage-nav-contactme, .homepage-nav-graphicdesign, .homepage-nav-miscartwork, .homepage-nav-webdesign, .logo{
    background: url(/resource/img/sprites.png) no-repeat;
}

.nav-aboutme {
    background-position: -81px -361px ;
    width: 76px;
    height: 105px;
    margin-right: 49px;
}

.nav-contactme {
    background-position: 0 -360px ;
    width: 76px;
    height: 105px;
}

.nav-graphicdesign {
    background-position: -79px -246px ;
    width: 89px;
    height: 105px;
    margin-right: 49px;
}

.nav-homepage {
    background-position: 0 -245px ;
    width: 76px;
    height: 105px;
    margin-right: 49px;
}

.nav-miscartwork {
    background-position: -79px -132px ;
    width: 85px;
    height: 105px;
    margin-right: 49px;
}

.nav-webdesign {
    background-position: 0 -132px ;
    width: 76px;
    height: 105px;
    margin-right: 49px;
}
Run Code Online (Sandbox Code Playgroud)

小智 5

我相信这是因为块元素里面没有内容。如果在锚链接内添加一个字母,锚链接将变为 div 宽度的 100%。

如果添加 width:100% 和 height:100% 它将占据整个 div。