Проблема с выравниванием предметов - PullRequest
0 голосов
/ 01 февраля 2019

Мне нужно перечислить 3 элемента в каждой строке, что хорошо работает для настольной версии, но на некоторых устройствах это не так быстро.Элементы перекрываются на iPad, поэтому, когда я нажимаю на ссылку элемента, он не открывается.А текст внутри некоторых предметов длиннее, поэтому я чувствую, что даже это проблема

Я пробовал использовать дисплей: Flex и Grid, но все прошло напрасно.

Подарочный товар

gift = [{ image_url ,Price of the item, Name of the gift }]

giftResults {
  margin: 0 -5px;
}

.giftResults:after {
  content: "";
  display: table;
  clear: both;
}

.error {
  color: red;
}

.giftResult {
  float: left;
  width: 25%;
  padding: 0 10px;
}

.gift-container {
  width: 940px;
  max-width: 100%;
  min-width: 768px;
  margin: 0 auto;
  padding: 0 0;
  padding-bottom: 3em;
}

.card {
  background-color: #e5474b;
  display: inline-block;
  /* width: 25%; */
  height: 50%;
  margin-top: 30px;
  width: 33.33333%;
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
  padding: 16px;
  text-align: center;
}

.card a {
  display: block;
}

.card h2 {
  padding-bottom: 25px;
  font-size: 20px;
  height: 35px;
}

.card:hover {
  height: 55%;
  width: 39%;
}

@media screen and (max-width: 600px) {
  .giftResult {
    width: 100%;
    display: block;
    margin-bottom: 20px;
  }
  .card {
    background-color: #e5474b;
    max-width: 400px;
    display: block;
    height: 50%;
    margin-top: 30px;
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
    padding: 16px;
    text-align: center;
    width: fit-content;
  }
}
<div className="giftResults">
  <ul>{ giftDetails }
    <li className="giftResult">
      <div className="gift-container">
        <div className="card">
          <img src={props.imageUrl} alt="Item" />
          <p>{`$ ${props.price}`}</p>
          <a href={props.url} target="_blank" rel="noopener noreferrer">
    		 {props.name}
    	  </a>
        </div>
      </div>
    </li>

  </ul>
</div>

Ответы [ 3 ]

0 голосов
/ 01 февраля 2019

Я не совсем уверен, что вы хотите, может быть несколько результатов, например:

  1. У вас есть 3 элемента подряд, когда экран меньше, элементы складываются сверху
  2. Элементы уменьшаются в размере и остаются в одном ряду

Если вы хотите, чтобы элементы складывались друг на друга, это может помочь вам (это очень простоВы должны обновить его в соответствии с вашими потребностями):

.singleItemContainer {
  display: inline-block;
  width: 200px;
  height: 200px;
  background-color: #e6e6e6;
  margin: 4px;
}
<div class="itemsContainer">
  <div class="singleItemContainer">

    <div class="">
      Title
    </div>
    <div class="">
      Text
    </div>
    <div class="">
      Image
    </div>
  </div>
  <div class="singleItemContainer">
    <div class="">
      Title
    </div>
    <div class="">
      Text
    </div>
    <div class="">
      Image
    </div>
  </div>
  <div class="singleItemContainer">
    <div class="">
      Title
    </div>
    <div class="">
      Text
    </div>
    <div class="">
      Image
    </div>
  </div>
</div>

Если вы хотите, чтобы элементы уменьшались в размере (в частности, в ширину), то вы бы изменили ширину на 33,33% (без разрыва между ними, есливы хотите, чтобы между ними было пространство, тогда вам просто нужно отрегулировать ширину элементов в зависимости от того, сколько места / отступов вы даете элементам).

Для мобильных размеров у вас есть возможность использовать медиа-запросы,Вы можете объединить оба решения здесь и добавить медиазапросы, логика будет заключаться в том, что, например, от размера экрана 320px до 600px элементы будут накладываться друг на друга, после 600px элементы будут иметь ширину 33,33%.

Для этого вам понадобится медиа-запрос:

 .singleItemContainer{
    display: inline-block;
    width: 200px;
    height: 200px;
    background-color: #e6e6e6;
    margin: 4px;
}
 @media only screen and (min-width: 320px) { //This one is probably not needed since the width: 200px; is the default one, but just threw this in here to help understand the example
    .singleItemContainer{
       width: 200px;
    }
 } 
 @media only screen and (min-width: 600px) {
    .singleItemContainer{
       width: 31.33%; //31 to allow the margins in between
    }
 }

Медиа-запросы могут быть добавлены и настроены в соответствии с вашими потребностями, все здесь действительно может.Надеюсь, это поможет!

0 голосов
/ 05 февраля 2019

Я даже удалил лишний div

  <div className="gift-container">

, который вызывал проблему, и даже добавил медиа-запросы в соответствии с приведенными выше предложениями

0 голосов
/ 01 февраля 2019

Если вы не можете использовать бутстрап, посмотрите ниже ...

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {...} 

/* Small devices (portrait tablets and large phones, 600px and up) */
@media only screen and (min-width: 600px) {
     /*Define the new css rules 
} 

/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (min-width: 768px) {...} 

/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {...} 

/* Extra large devices (large laptops and desktops, 1200px and up) */
@media only screen and (min-width: 1200px) {...}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...