: после того, как элемент с вращением перемещается на изменение размера

У меня есть элемент: before и an: after (для теневых целей) с примененным к нему transform: rotate.:: Before остается на месте, когда размер области просмотра изменяется, однако: after немного перемещается вверх и вниз. Если поворот будет удален, он останется на месте при изменении размера. Как я могу сделать так, чтобы он оставался на месте при изменении размера с помощью roate?

Я поставил z-index: 1 для: before и: after для наглядности проблемы

Это тень № 3

http://codepen.io/mildrenben/details/jEYpyP/

HTML:

<h2>Shadow #3</h2>
<div class="row shadow-3">
  <div class="shadow-box">
    <img>
  </div>
  <div class="shadow-box">
    <img>
  </div>
  <div class="shadow-box">
    <img>
  </div>
  <div class="shadow-box">
    <img>
  </div>
</div>

CSS:

html, body {
  width: 100%;
  height: 100%;
}
.row {
  height: 160px;
  width: 80%;
  margin: 0 auto 60px;
  display: block;
    img:nth-of-type(1) {
      content: url(http://marshall.org/wp-content/themes/marshall/img/featured-space-policy.jpg);
    }
    img:nth-of-type(2) {
      content: url(http://i.dailymail.co.uk/i/pix/2014/09/04/1409790551890_wps_28_Astronaut_Reid_Wiseman_po.jpg);
    }
    img:nth-of-type(3) {
      content: url(http://cdn2.collective-evolution.com/assets/uploads/2014/08/life_in_space-728x400.jpg);
    }
    img:nth-of-type(4) {
      content: url(http://s.ngm.com/2007/10/space-travel/img/space_feature.jpg);
    }
}

img {
  width: 23%;
  margin: 0 1% 0 0;
  height: 100%;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.shadow-box {
  width: 23%;
  margin: 0 1% 0 0;
  height: 100%;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  display: inline-block;
  img {
    width: 100%;
    height: 100%;
    &:hover {
      transform: translateY(-4px);
    }
  }
}

.shadow-box:before, .shadow-box:after {
  content: '';
  z-index: 1;
  position: absolute;
  width: 8%;
  height: 110px;
  background: red;
  transform: skew(-10deg) rotate(-6deg) translate(calc(3% + 10px), 31px);
  transition: all 0.2s ease-in-out;
}

.shadow-box:after {
  transform: skew(10deg) rotate(6deg) translate(126%, -146px);
}

.shadow-box:hover:before, .shadow-box:hover:after {
  box-shadow: 0 20px 20px lighten($black, 40%);
}

1 ответ

Решение

Я не думаю, что с помощью перевода это путь, я бы установил контейнер в положение: относительный; а затем использовать абсолютное позиционирование для позиционирования теневых объектов: http://jsfiddle.net/bpma9ko4/

Здесь соответствующие части:

.shadow-box {
  width: 45%;
  margin: 0 1% 0 0;
  height: 100%;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  display: inline-block;
  position: relative;
}

.shadow-box:before, .shadow-box:after {
  content: '';
  z-index: 1;
  position: absolute;
  width: 40%;
  height: 110px;
  background: red;
  transform: skew(-10deg) rotate(-6deg);
  transition: all 0.2s ease-in-out;
  top: 20px;
  left: 20px;
}

.shadow-box:after {
  transform: skew(10deg) rotate(6deg);
  right: 20px;
  left: auto;
}

В вашем примере, когда я удалил переводы, красная рамка справа ушла под изображение (на новой строке), а затем вы попытались перетащить его с помощью переводов, но для меня это гораздо более прямой способ, если вы просто поместите для начала над изображением, используя атрибуты top/left/right.

Примечание: мой пример упрощен, в нем нет теней и прочего, он разбит на части, относящиеся к вопросу.

Весь код:

html, body {
  width: 100%;
  height: 100%;
}
.row {
  height: 160px;
  width: 80%;
  margin: 0 auto 60px;
  display: block;
    img:nth-of-type(1) {
      content: url(http://marshall.org/wp-content/themes/marshall/img/featured-space-policy.jpg);
    }
    img:nth-of-type(2) {
      content: url(http://i.dailymail.co.uk/i/pix/2014/09/04/1409790551890_wps_28_Astronaut_Reid_Wiseman_po.jpg);
    }
    img:nth-of-type(3) {
      content: url(http://cdn2.collective-evolution.com/assets/uploads/2014/08/life_in_space-728x400.jpg);
    }
    img:nth-of-type(4) {
      content: url(http://s.ngm.com/2007/10/space-travel/img/space_feature.jpg);
    }
}

img {
  width: 100%;
  margin: 0 1% 0 0;
  height: 100%;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.shadow-box {
  width: 45%;
  margin: 0 1% 0 0;
  height: 100%;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  display: inline-block;
    position: relative;
}

.shadow-box:before, .shadow-box:after {
  content: '';
  z-index: 1;
  position: absolute;
  width: 40%;
  height: 110px;
  background: red;
  transform: skew(-10deg) rotate(-6deg);
  transition: all 0.2s ease-in-out;
    top: 20px;
    left: 20px;
}

.shadow-box:after {
  transform: skew(10deg) rotate(6deg);
    right: 20px;
    left: auto;
}

.shadow-box:hover:before, .shadow-box:hover:after {
  box-shadow: 0 20px 20px lighten($black, 40%);
}
<h2>Shadow #3</h2>
<div class="row shadow-3">
  <div class="shadow-box">
    <img src="http://placehold.it/466x180">
  </div>
  <div class="shadow-box">
    <img src="http://placehold.it/466x180">
  </div>
  <div class="shadow-box">
    <img src="http://placehold.it/466x180">
  </div>
  <div class="shadow-box">
      <img src="http://placehold.it/466x180">
  </div>
</div>

Другие вопросы по тегам