Использование Bootstrap для размещения диапазона под div - PullRequest
2 голосов
/ 15 июня 2019

Я пытаюсь внедрить больше элементов Bootstrap в проект, над которым я работаю. У меня есть круглый div с текстом под ним «Перейти на домашнюю страницу». Я бы хотел, чтобы интервал располагался по центру ниже div и находился на одной строке - как мне это сделать с помощью Bootstrap?

.avatar {
	margin: 10px;
	border-radius: 50%;
	height: 90px;
	text-align: center;
	width: 90px;
	float: right;
	border: 5px solid #fafafa;
  background-color: blue;
}

.initials {
	font-size: 2rem;/* 50% of parent */
	position: relative;
	top: 1.2rem; /* 25% of parent */
	color: #fafafa;
	font-weight: 700;
	}
  
  .update-homepage-link {
	float: right;
	color: #fafafa;
	font-weight: bold;
  color: pink;
}
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<div class="col-6 col-xl-2 order-xl-3">
				<div class="avatar">
					<span class="initials"> WW </span>
				<a class="update-homepage-link" href="">Go to Homepage</a>
			</div>

Раньше я использовал следующее для центрирования ниже круглого div, но меня попросили завершить проект в Bootstrap. Я экспериментировал с дистанционными классами, но не выбрал правильную комбинацию. Кто-нибудь может дать какие-либо предложения?

Ответы [ 2 ]

0 голосов
/ 15 июня 2019

Я заново создал ваш фрагмент, поместив решение под старый HTML.

Я использовал компонент Bootstrap Card для решения проблемы и некоторые другие пользовательские классы.

.avatar {
  margin: 10px;
  border-radius: 50%;
  height: 90px;
  text-align: center;
  width: 90px;
  float: right;
  border: 5px solid #fafafa;
  background-color: blue;
}

.initials {
  font-size: 2rem;
  /* 50% of parent */
  position: relative;
  top: 1.2rem;
  /* 25% of parent */
  color: #fafafa;
  font-weight: 700;
}

.update-homepage-link {
  float: right;
  color: #fafafa;
  font-weight: bold;
  color: pink;
}


/* Classes for the solution */

.card.avatar-card {
  border: none;
  border-radius: 0;
}

.card-img-top.avatar-bs {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  border: 5px solid #fafafa;
  background-color: blue;
  justify-content: center;
  align-self: center;
}

.initials-bs {
  align-self: center;
  font-size: 2rem;
  color: #fafafa;
  font-weight: 700;
}

.update-homepage-link-bs {
  color: #fafafa;
  font-weight: bold;
  color: pink;
}
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet" />
<div class="container">
  <div class="row">
    <div class="col-6 col-xl-2 order-xl-3">
      <div class="avatar">
        <span class="initials">WW</span>
        <a class="update-homepage-link" href="">Go to Homepage</a>
      </div>
    </div>
  </div>
  <!-- SOLUTION -->
  <div class="row">
    <div class="col-6 col-xl-2 order-xl-3">
      <div class="card avatar-card" style="width: 18rem">
        <div class="card-img-top avatar-bs d-flex">
          <span class="initials-bs d-flex"> WW </span>
        </div>
        <div class="card-body text-center">
          <a class="card-title update-homepage-link-bs" href="">Go to Homepage</a>
        </div>
      </div>
    </div>
  </div>
</div>
0 голосов
/ 15 июня 2019

Это не имеет ничего общего с начальной загрузкой, пожалуйста, посмотрите на модифицированный CSS. Если вы хотите центрировать содержимое, оберните весь div в другой div с классом 'text-center'.

.avatar {
	margin: 10px;
	border-radius: 50%;
	height: 90px;
	text-align: center;
	width: 90px;
	border: 5px solid #fafafa;
  background-color: blue;
}

.initials {
	font-size: 2rem;/* 50% of parent */
	position: relative;
	top: 1.2rem; /* 25% of parent */
	color: #fafafa;
	font-weight: 700;
	}
  
  .update-homepage-link {
	color: #fafafa;
	font-weight: bold;
  color: pink;
}
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<div class="col-6 col-xl-2 order-xl-3">
				<div class="avatar">
					<span class="initials"> WW </span>
			    </div>
                <a class="update-homepage-link" href="">Go to Homepage</a>
...