html - 带有反圆 Angular 的 css3 菜单

标签 html css menu css-shapes rounded-corners

我设计了一个导航菜单,如下图所示:

inverse rounded corners

我想使用 css3 圆 Angular 和框阴影对其进行编码,而不使用任何图像。 问题是第一个菜单项左侧的圆 Angular 和菜单右侧的圆 Angular ...我称之为“反向”圆 Angular ...

它应该在 :hover 上改变颜色。

有什么方法可以只用 css 来完成这个任务吗?又如何?

最佳答案

HTML

<div class="menu">
    <div class="outer_bg_left">
        <div class="outer">
            <div class="outer_shadow">
            </div>
        </div>   
    </div>

    <ul>
        <li class="menu_item_cont"><div class="menu_item">Item 1</div></li>
        <li class="menu_item_cont"><div class="menu_item">Item 2</div></li>
        <li class="menu_item_cont"><div class="menu_item">Item 3</div></li>
    </ul>

    <div class="outer_bg_right">
        <div class="outer">
            <div class="outer_shadow">
            </div>
        </div>   
    </div>
</div>

CSS

.outer_bg_left, .outer_bg_right {
    float: left;
    width: 70px;
    background-color: #994;
    height: 15px;
    overflow: hidden;
    position: relative;
    z-index: 10;
}

.outer_bg_left .outer {
    height: 25px;
    border-radius:  0 10px 0 0;
    background-color: #fff;
}

.outer_bg_right .outer {
    height: 25px;
    border-radius:  10px 0 0 0;
    background-color: #fff;
}

.outer_bg_left .outer_shadow, .outer_bg_right .outer_shadow {
    box-shadow:  0 0 5px 2px rgba(0,0,0, .7) inset;
    padding-bottom: 10px;
    margin-bottom: -10px;
    height: 25px;
}

.outer_bg_left .outer_shadow {
    border-radius: 0 10px 0 0;
    padding-left: 30px;
    margin-left: -30px;
}

.outer_bg_right .outer_shadow {
    border-radius:  10px 0px 0 0;
    padding-right: 30px;
    margin-right: -30px;
}

.menu_item_cont {
    background-color: #994;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 0 5px 2px rgba(0,0,0, .7);
    background-color: #994;
    display: block;
    float: left;
}

.menu_item {   
    border-radius: 0 0 10px 10px;
    background-color: #994;
    height: 20px;
    padding: 5px 10px;

    font-family: Arial;
    line-height: 20px;
    font-size: 14px;
    font-weight: bold;
}

.menu_item:hover {
    background-color: #000;
    border-radius: 10px;
    height: 30px;
    line-height: 30px;
    color: #fff;
}

http://jsfiddle.net/gXQzU/4/

这只是我的第一次尝试,但我认为它看起来很有希望。

关于html - 带有反圆 Angular 的 css3 菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8929173/

相关文章:

javascript - 在 Javascript 中,如何在不指定 rgb 的情况下设置 rgba?

javascript - 在下拉菜单的 li 元素旁边显示 div

html - <li> 上的下拉菜单 CSS 填充超出了容器

html - 如何覆盖 CSS 类?

jquery - CSS 应该工作取决于 html 类名结构

html - CSS/HTML 中的元素不可见

android - 选项菜单不起作用

html - 即使应用了 reset.css,不同浏览器的输出也不同

html - 选择样式的文本元素

Javascript 更改表格单元格的 src