Положение и центрирование круглой формы внутри ячейки списка в CSS - PullRequest
0 голосов
/ 25 января 2020

У меня проблема с позиционированием и центрированием круглой формы в ячейке горизонтального списка.

У меня есть класс для моего cicrle:

.user-logo {
    background-color: #4CAF50;
    border: none;
    border-radius: 50%;
    height: 50px;
    width: 50px;
    text-align: center;
}

И класс для списка:

.navbar-list {
    @extend ul;
    height: $navbar-height;
    float: right;  

    li {
        float:left;
    }

    a {
        display: block;
        margin: 0 auto;
        padding-left: 5px;
        padding-right: 5px;
    }

    li a:hover {
        background-color: #111;
    }
}

Я работаю с реагировать, поэтому использование класса выглядит this:

<ul className='navbar-list'>
    <li><NavLink to='/'>New Project</NavLink></li>
    <li><NavLink to='/'>Log Out</NavLink></li>
    <li><NavLink to='/' className='user-logo'>NN</NavLink></li>
</ul>

Как мне отрегулировать положение моей круглой формы внутри ячейки? На данный момент текст моего Navbar хорошо отображается - в середине каждой ячейки (даже текст моего круга), но мой круг все еще выровнен по верхнему левому углу ячейки.

Ответы [ 2 ]

0 голосов
/ 25 января 2020

Вы можете использовать ниже CSS код:

.user-logo {
  background-color: #4caf50;
  border: none;
  border-radius: 50%;
  height: 50px;
  width: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.navbar-list {
  height: 50px;
  justify-content: flex-end;
  display: flex;
  align-items: center;
}
.navbar-list li {
  list-style-type: none;
}
.navbar-list li a {
  padding-left: 5px;
  padding-right: 5px;
}
.navbar-list li a:hover {
  background-color: #111;
}
0 голосов
/ 25 января 2020

Один из способов - превратить родительский элемент во flexbox, выполнив:

li{ display: flex; }

Для получения дополнительной информации о flexbox css вы можете посмотреть здесь или другие учебные пособия в Интернете.

В противном случае убедитесь, что у вашей круглой формы есть display: inline-block, чтобы вы могли контролировать ее вертикальное положение с полями и попытаться оптимизировать с помощью ровных верхних и нижних полей на круглой или верхней поверхности и нижние отступы на родительском элементе.

...