具有倾斜边缘的Div保持纵横比

Jac*_*Dev 4 html css html5 css3

我正在尝试创建具有倾斜边缘的标题,无论它们出现的高度如何都能保持其纵横比.这可以单独使用CSS吗?

此图像显示如果标题只有一行,标题会是什么样子:

如果它们长两行或多行,它们应该看起来像:

我遇到的问题是,我不能使覆盖标题右侧部分的白色半三角形调整大小,更不用说以相同的宽高比调整大小.以下是多行上发生的情况:

现在显示标题的代码是:

HTML:

<header>
    <nav>
        <ul>
            <li><a href="#">Public Information</a></li>
        </ul>
    </nav>
    <h1>Board Meeting Schedule</h1>
</header>
Run Code Online (Sandbox Code Playgroud)

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;
    }
Run Code Online (Sandbox Code Playgroud)

这里有一个小提琴:http://jsfiddle.net/doLuj6me/

Jos*_*ess 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;
}
Run Code Online (Sandbox Code Playgroud)

这就是它的核心.我们在标题的末尾放置一个伪元素,将其扭曲45度并使其变得如此之大以至于它将覆盖任何合理的大小.

小提琴说明了这一点hackery

瞧.