1

所以我尝试前后试验CSS伪类。我尝试使用这些伪来创建标题元素。这是为了减少使用 div 来保存左右图像。这是 HTML 的代码

    <header id="mastHead">
        <h1><a href="#">Branding</a></h1>
    </header>

所以我有 3 个图像来创建传统的标题元素,左侧和右侧宽度为 20 像素,高度为 100 像素,中间为 1 像素宽度和 100 像素高度,将水平重复。这里是我的 CSS

    #mastHead {
        background:url(images/headMiddle.jpg) repeat-x top left;
        width:1000px;
        height:100px;
        overflow:hidden;
    }

    #mastHead:before {
        content:"";
        display:block;
        background:url(images/headLeft.jpg) no-repeat top left;
        width:20px;
        height:100px;
        float:left;
    }

    #mastHead:after {
        content:"";
        display:block;
        background:url(images/headRight.jpg) no-repeat top left;
        width:20px;
        height:100px;
        float:right;
    }

    #mastHead h1 a {
        display:block;
        width:200px;
        height:41px;
        background:url(images/logo.png) no-repeat;
    }

所以问题是如果我删除 h1 元素,它会完美对齐,但是如果我放置这些元素,它会将 ::after 伪类向下推,它会根据它的高度占用剩余空间。我怎样才能制作这个 h1 元素只占用中间空间而不影响 ::after 空间?

4

1 回答 1

1

我用你的例子做了一个小提琴:http: //jsfiddle.net/3Dcw3/(只将宽度设置为500以适应小提琴并设置背景以可视化它们)

这是一个固定版本:http: //jsfiddle.net/3Dcw3/1/

要点是:

  1. 添加position:relative;到标题。
  2. 使用绝对定位而不是浮动。
  3. 添加填充,以便块位于它们之上。
于 2011-08-11T22:40:09.833 回答