learningbyexample
learningbyexample

Reputation: 1547

How do I add curved corners to menu in css

I want to curve the corners in css in .second-level-menu.

I tried to add in .second-level-menu and in .second-level-menu > li:

border-radius: 0px 0px 8px 8px; 
-moz-border-radius: 0px 0px 8px 8px; 
-webkit-border-radius: 0px 0px 8px 8px; 

/* Menu Styles */

.third-level-menu {
  position: absolute;
  top: 0;
  right: -150px;
  width: 150px;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
}
.third-level-menu > li {
  height: 30px;
  background: #999999;
}
.third-level-menu > li:hover {
  background: #CCCCCC;
}
.second-level-menu {
  position: absolute;
  top: 30px;
  left: 0;
  width: 150px;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
}
.second-level-menu > li {
  position: relative;
  height: 30px;
  background: #999999;
}
.second-level-menu > li:hover {
  background: #CCCCCC;
}
.top-level-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.top-level-menu > li {
  position: relative;
  float: left;
  height: 30px;
  width: 150px;
  background: #999999;
}
.top-level-menu > li:hover {
  background: #CCCCCC;
}
.top-level-menu li:hover > ul {
  /* On hover, display the next level's menu */
  display: inline;
}
/* Menu Link Styles */

.top-level-menu a
/* Apply to all links inside the multi-level menu */

{
  font: bold 14px Arial, Helvetica, sans-serif;
  color: #FFFFFF;
  text-decoration: none;
  padding: 0 0 0 10px;
  /* Make the link cover the entire list item-container */
  display: block;
  line-height: 30px;
}
.top-level-menu a:hover {
  color: #000000;
}
<ul class="top-level-menu">
  <li><a href="#">About</a>
  </li>
  <li><a href="#">Services</a>
  </li>
  <li>
    <a href="#">Offices</a>
    <ul class="second-level-menu">
      <li><a href="#">Chicago</a>
      </li>
      <li><a href="#">Los Angeles</a>
      </li>
      <li>
        <a href="#">New York</a>
        <ul class="third-level-menu">
          <li><a href="#">Information</a>
          </li>
          <li><a href="#">Book a Meeting</a>
          </li>
          <li><a href="#">Testimonials</a>
          </li>
          <li><a href="#">Jobs</a>
          </li>
        </ul>
      </li>
      <li><a href="#">Seattle</a>
      </li>
    </ul>
  </li>
  <li><a href="#">Contact</a>
  </li>
</ul>

Upvotes: 3

Views: 247

Answers (2)

sinisake
sinisake

Reputation: 11318

If you add overflow: hidden, it partially solves problem, but then your third level menu is invisible. I would just add:

.second-level-menu > li:last-child {
  border-radius: 0px 0px 8px 8px;
}

Demo: https://jsfiddle.net/cw8w6rwr/

(same for third level menu, if needed)

/* Menu Styles */

.third-level-menu {
  position: absolute;
  top: 0;
  right: -150px;
  width: 150px;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
}
.third-level-menu > li {
  height: 30px;
  background: #999999;
}
.third-level-menu > li:hover {
  background: #CCCCCC;
}
.second-level-menu {
  position: absolute;
  top: 30px;
  left: 0;
  width: 150px;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
  
 
}
.second-level-menu > li {
  position: relative;
  height: 30px;
  background: #999999;
  
}
.second-level-menu > li:last-child {
  border-radius: 0px 0px 8px 8px;
}

.second-level-menu > li:hover {
  background: #CCCCCC;
}
.top-level-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.top-level-menu > li {
  position: relative;
  float: left;
  height: 30px;
  width: 150px;
  background: #999999;
}
.top-level-menu > li:hover {
  background: #CCCCCC;
}
.top-level-menu li:hover > ul {
  /* On hover, display the next level's menu */
  display: inline;
}
/* Menu Link Styles */

.top-level-menu a
/* Apply to all links inside the multi-level menu */

{
  font: bold 14px Arial, Helvetica, sans-serif;
  color: #FFFFFF;
  text-decoration: none;
  padding: 0 0 0 10px;
  /* Make the link cover the entire list item-container */
  display: block;
  line-height: 30px;
}
.top-level-menu a:hover {
  color: #000000;
}
<ul class="top-level-menu">
  <li><a href="#">About</a>
  </li>
  <li><a href="#">Services</a>
  </li>
  <li>
    <a href="#">Offices</a>
    <ul class="second-level-menu">
      <li><a href="#">Chicago</a>
      </li>
      <li><a href="#">Los Angeles</a>
      </li>
      <li>
        <a href="#">New York</a>
        <ul class="third-level-menu">
          <li><a href="#">Information</a>
          </li>
          <li><a href="#">Book a Meeting</a>
          </li>
          <li><a href="#">Testimonials</a>
          </li>
          <li><a href="#">Jobs</a>
          </li>
        </ul>
      </li>
      <li><a href="#">Seattle</a>
      </li>
    </ul>
  </li>
  <li><a href="#">Contact</a>
  </li>
</ul>

Upvotes: 2

Benneb10
Benneb10

Reputation: 1489

It works with border-radius, you just can't see it because the overlapping li elements. Setting overflow:hidden to .second-level-menu will cause the radius to show.

/* Menu Styles */

.third-level-menu {
  position: absolute;
  top: 0;
  right: -150px;
  width: 150px;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
}
.third-level-menu > li {
  height: 30px;
  background: #999999;
}
.third-level-menu > li:hover {
  background: #CCCCCC;
}
.second-level-menu {
  position: absolute;
  top: 30px;
  left: 0;
  width: 150px;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
  border-radius:0px 0px 8px 8px;
  overflow:hidden;
}
.second-level-menu > li {
  position: relative;
  height: 30px;
  background: #999999;
}
.second-level-menu > li:hover {
  background: #CCCCCC;
}
.top-level-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.top-level-menu > li {
  position: relative;
  float: left;
  height: 30px;
  width: 150px;
  background: #999999;
}
.top-level-menu > li:hover {
  background: #CCCCCC;
}
.top-level-menu li:hover > ul {
  /* On hover, display the next level's menu */
  display: inline;
}
/* Menu Link Styles */

.top-level-menu a
/* Apply to all links inside the multi-level menu */

{
  font: bold 14px Arial, Helvetica, sans-serif;
  color: #FFFFFF;
  text-decoration: none;
  padding: 0 0 0 10px;
  /* Make the link cover the entire list item-container */
  display: block;
  line-height: 30px;
}
.top-level-menu a:hover {
  color: #000000;
}
<ul class="top-level-menu">
  <li><a href="#">About</a>
  </li>
  <li><a href="#">Services</a>
  </li>
  <li>
    <a href="#">Offices</a>
    <ul class="second-level-menu">
      <li><a href="#">Chicago</a>
      </li>
      <li><a href="#">Los Angeles</a>
      </li>
      <li>
        <a href="#">New York</a>
        <ul class="third-level-menu">
          <li><a href="#">Information</a>
          </li>
          <li><a href="#">Book a Meeting</a>
          </li>
          <li><a href="#">Testimonials</a>
          </li>
          <li><a href="#">Jobs</a>
          </li>
        </ul>
      </li>
      <li><a href="#">Seattle</a>
      </li>
    </ul>
  </li>
  <li><a href="#">Contact</a>
  </li>
</ul>

Upvotes: 2

Related Questions