具有倾斜边缘且保持宽高比的 Div 元素

4
我正在尝试创建具有倾斜边缘的标题,无论其高度如何,它们都可以保持其纵横比。是否可能仅使用CSS完成此操作?
如果只有一行,这张图片展示了标题的样子:
//i.imgur.com/akWns0H.jpg
如果是两行或更多行,则应该呈现为:
//i.imgur.com/a44DNXO.jpg
我遇到的问题是,我无法使覆盖标题右侧部分的白色半三角形调整大小,更不能以相同的纵横比调整大小。以下是原始代码所呈现的多行效果:
//i.imgur.com/kNLvmV3.jpg
现在,显示标题的代码是:
HTML:
<header>
    <nav>
        <ul>
            <li><a href="#">Public Information</a></li>
        </ul>
    </nav>
    <h1>Board Meeting Schedule</h1>
</header>

CSS(层叠样式表):
* {
    font-family: sans-serif;
    font-size: 16px;
    font-weight: normal;
    line-height: normal;
    margin: 0;
}

header {
    background: #0D3C5B;
    display: inline-block;
    overflow: hidden;
    padding: 18px 80px 12px 20px;
    position: relative;
}
    header:before {
        border-left: 58px solid transparent;
        border-top: 62px solid #FFF;
        content: "\0020";
        display: block;
        height: 0;
        position: absolute;
        right: 0;
        top: 0;
        width: 0;
    }

    header nav {
        float: left;
        margin: 0 6px 0 0;
    }

        header nav ul {
            color: #42AFE3;
            display: inline-block;
            font-size: 0.75em;
            font-weight: bold;
            line-height: 1.6666666666666666666666666666667em;
            line-height: 2.25em;
            list-style: normal;
            margin: 0;
            padding: 0;
            text-transform: uppercase;
        }

            header nav ul li {
                display: inline-block;
            }

                header nav ul li a {
                    color: #42AFE3;
                    text-decoration: none;
                }

                header nav ul li:after {
                    content: "\003E";
                    padding: 0 4px;
                }

    header h1 {
        color: #FFF;
        float: left;
        font-size: 1.25em;
        font-weight: bold;
        line-height: 1em;
        text-transform: uppercase;
    }

    header:after {
        clear: both;
        content: "\0020";
        display: block;
        visibility: hidden;
    }

这里有一个演示: http://jsfiddle.net/doLuj6me/

涉及到it技术,具体内容暂时无法确定。

我宁愿使用背景图片来解决这个问题。 - el Dude
我不会选择使用背景图片,因为它们不能很好地进行缩放。在可能的情况下,我总是更喜欢使用CSS。 - JacobTheDev
4个回答

6

是的!三角形边框技巧非常棒,但不幸的是,对于动态大小的元素来说非常不灵活。

幸运的是,CSS3给我们提供了一些新的工具,可以用于富有创意的方式。

以下是操作步骤:

CSS

header {
    background: #0D3C5B;
    display: inline-block;
    overflow: hidden;
    padding: 18px 80px 12px 20px;
    position: relative;
}

header:before {
    content:'';
    transform:rotate(45deg);
    transform-origin: bottom right;
    height: 100%;
    width: 100%;
    background-color: white;
    position: absolute;
    right: 0;
}

这就是核心内容。我们在标题末尾添加伪元素,将其扭曲45º,并使其变得如此巨大,以至于它可以覆盖任何合理大小的区域。

演示此技巧的代码片段

完成。


0

这里有一个不使用变换或旋转的示例:

http://jsfiddle.net/ryanwheale/twxgnjcw/

尝试更改DIV的高度,您会发现斜线随着DIV一起增长。
div {
    height: 400px;
    background: blue;
    position: relative;
    overflow: hidden;
}

div:after {
    content: " ";
    position: absolute;
    width: 0;
    height: 0;
    left: 100%;
    bottom: -2000px;
    margin-left: -2000px;
    border-width: 2000px;
    border-style: solid;
    border-color: white transparent transparent;
}

0

Christopher 步入正轨。你所要做的就是将 header:before 定位在右下角,并给边框比你需要的尺寸更大:

header:before { 
    content: " ";
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    height: 0;
    width: 0;
    border-left: 400px solid transparent;
    border-top: 400px solid #FFF;
}

请查看Fiddle(更新链接以进行一些清理)。


0

尝试将直角三角形设为position:absolute;,right:0;,bottom:0;。您需要确保文本不会被覆盖,如果它变得过长... 还要确保包含的div具有overflow:clip设置,以使右侧三角形不会跑出div :)

嗯... 我错过了您没有单独的三角形元素。您应该将页眉分成一个容器,其中包括一个文本div和一个右三角形div。容器应该具有relative定位,而右三角形div则应按我上面提到的方式进行设置。


如果您想保持语义化的 HTML,以便于 SEO、可访问性和通用可读性,那么应该避免仅为样式而添加标签。这就是为什么我们有伪元素,它们不会污染 DOM。这只是一个小提示。 - Josh Burgess
很好,但您有更好的方法来实现他想要的吗?避免是可以的,但如果它可行且语义上正确的HTML无法实现它,那么这将是一个边缘情况,他会希望这样做。 - Christopher White
1
是的,请检查我的答案。 - Josh Burgess
不错...我对CSS3的更多奇特功能没有那么多经验。我会深入研究这个。谢谢。 - Christopher White

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接