html -::之前和不可见的背景图像

标签 html css

我想要一个带有左右图像的导航作为悬停效果(参见图片 navigation)。

我有这个代码:

HTML

<nav class="clearfix"> 
<ul class="clearfix">
<li><a href="#about">about</a></li>
<li><a href="#get_involved">get involved</a></li>
<li><a href="#kenia2016">kenia 2016</a></li>
<li><a href="#projects">projects</a></li>
<li><a href="#contact">contact</a></li>
</ul>
</nav>

CSS:

nav a:hover::before {
    content: "____";
    background: url('../img/mosterdseed_left.png') no-repeat;
    width: 200px;
    height: 200px;
}

当我删除 CSS 中的内容属性时,图像变得不可见。我怎样才能避免这种情况?

最佳答案

只写content: "";

然后您将拥有“空”内容。::before 和::after 伪元素需要添加 content 属性才能可见,但允许为空字符串。

但默认情况下::before和::after是行内元素,它们会忽略宽度和高度。一旦你绝对定位它们,它就会起作用。

下面是一个片段,显示了您需要添加什么才能使其正常工作。

nav a {
    /* To be able to absolutely possition the pseudo elements inside the link. */
    position: relative;
}

nav a:hover::before {
    background: url('../img/mosterdseed_left.png') no-repeat;
    width: 200px;
    height: 200px;
    
    /* To make the pseudo element visible in the first place. */
    content: "";

    /* To position the image */
    position: absolute;
    left: 0;
    top: 0;
  
    /* To make it visible, since the image cannot be loaded in the example */
    background-color: rgba(255, 0, 0, 0.3);
}
<nav class="clearfix"> 
<ul class="clearfix">
<li><a href="#about">about</a></li>
<li><a href="#get_involved">get involved</a></li>
<li><a href="#kenia2016">kenia 2016</a></li>
<li><a href="#projects">projects</a></li>
<li><a href="#contact">contact</a></li>
</ul>
</nav>

关于html -::之前和不可见的背景图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33331085/

相关文章:

javascript - 如何让图像在滚动时调整大小?

html - 为什么不使用 flex-wrap :wrap? 将 flex 元素换行到第二行

javascript - 共享 Web Workers 是否在单个页面重新加载、链接导航中持续存在

css - React Native 中的 Margin 或 Padding 速记

javascript - 在显示之前过滤 div,即在 ajax 滚动之前

css - 使用 Bootstrap,如何创建多个全屏 div 以相互堆叠

html - "display: table"和 "float:left"不考虑边距

javascript - 在 HTML5/JavaScript 游戏中使用图 block 创建平滑的光照过渡

Jquery Div滚动条向上显示元素和窗口滚动条保持不变(没有移动)

css - Twitter Bootstrap 中的 typeahead 下拉列表是什么类 ID