У меня есть элементы, которые я могу перетаскивать по контейнеру при щелчке мышью с помощью jQueryUI. Я также хотел бы переместить весь контейнер, но когда я ввожу перетаскивание, первый эффект перестает работать.

Вот это с первым эффектом (он работает, когда вы щелкаете мышью и немного перетаскиваете) и как только я добавлю функцию перетаскивания с jQueryUI, у меня будет работать только эффект перетаскивания.

Есть ли способ, чтобы оба эффекта работали одновременно?

function parallax(e) {
  document.querySelectorAll(".object").forEach(function(move) {
    var moving_value = move.dataset.value;
    var x = (e.clientX * moving_value) / 250;
    var y = (e.clientY * moving_value) / 250;
    move.style.transform = `translateX(${x}px) translateY(${y}px)`;
  });
}

let mousedown = false;

$('body').on({
  mousedown: () => mousedown = true,
  mouseup: () => mousedown = false,
  mouseleave: () => mousedown = false,
  mousemove: e => mousedown && parallax(e)
});

$('.container').draggable({
  scroll: false,
  containment: '#grid'
});
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Segoe UI", sans-serif;
  background: #666 url(bg.png) no-repeat;
  background-size: cover;
  height: 100vh;
}

#grid {
  position: fixed;
  width: 120%;
  height: 120%;
  left: -10%;
  top: -10%;
}

.container {
  position: relative;
  width: 90%;
  height: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  user-select: none;
}

.container img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  object-fit: contain;
  pointer-events: none;
}

.container h2 {
  z-index: 1;
  position: relative;
  color: #fff;
  font-size: 90px;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: 32px;
  line-height: 60px;
}

.container h2 span {
  font-size: 48px;
  font-weight: 500;
  letter-spacing: 10px;
}

@media (max-width:800px) {
  .container h2 {
    font-size: 60px;
    letter-spacing: 19px;
    line-height: 35px;
  }
  .container h2 span {
    font-size: 26px;
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<div id="grid">
  <div class="container">
    <h2 class="object" data-value="3">Space<br><span>Background</span></h2>
    <img src="https://i.imgur.com/5yrwyPE.png" class="object" data-value="-2" alt="">
    <img src="https://i.imgur.com/C688O6f.png" class="object" data-value="2" alt="">
    <img src="https://i.imgur.com/zQMI9zR.png" class="object" data-value="1" alt="">
    <img src="https://i.imgur.com/JSzKUzo.png" class="object" data-value="-3" alt="">
    <img src="https://i.imgur.com/dxgHvQV.png" class="object" data-value="3" alt="">
    <img src="https://i.imgur.com/kbNROja.png" class="object" data-value="-2" alt="">
    <img src="https://i.imgur.com/2Ud0NwP.png" class="object" data-value="1" alt="">
    <img src="https://i.imgur.com/c5BGOj2.png" class="object" data-value="-3" alt="">
    <img src="https://i.imgur.com/Qxs8luV.png" class="object" data-value="0" alt="">
  </div>
</div>
1
DearBee 3 Фев 2022 в 13:26
Вы можете рассмотреть возможность переноса вызова parallax(e) в обратный вызов Draggables drag.
 – 
Twisty
3 Фев 2022 в 18:50

2 ответа

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

С ним все еще есть некоторые проблемы, например, когда вы нажимаете и перетаскиваете второй раз, он начинается с предыдущей позиции...

В любом случае, если кому-то это нужно, просто увеличьте числовое значение data-value, и все будет готово.

0
DearBee 3 Фев 2022 в 16:33

Похоже, у вас уже есть ответ, и вы можете рассмотреть следующее.

$(function() {
  function parallax(e) {
    $(".object").each(function(i, move) {
      var moving_value = move.dataset.value;
      var x = (e.clientX * moving_value) / 250;
      var y = (e.clientY * moving_value) / 250;
      move.style.transform = `translateX(${x}px) translateY(${y}px)`;
    });
  }

  $('.container').draggable({
    scroll: false,
    containment: '#grid',
    drag: function(event, ui) {
      parallax(event);
    }
  });
});
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Segoe UI", sans-serif;
  background: #666 url(bg.png) no-repeat;
  background-size: cover;
  height: 100vh;
}

#grid {
  position: fixed;
  width: 120%;
  height: 120%;
  left: -10%;
  top: -10%;
}

.container {
  position: relative;
  width: 90%;
  height: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  user-select: none;
}

.container img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  object-fit: contain;
  pointer-events: none;
}

.container h2 {
  z-index: 1;
  position: relative;
  color: #fff;
  font-size: 90px;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: 32px;
  line-height: 60px;
}

.container h2 span {
  font-size: 48px;
  font-weight: 500;
  letter-spacing: 10px;
}

@media (max-width:800px) {
  .container h2 {
    font-size: 60px;
    letter-spacing: 19px;
    line-height: 35px;
  }
  .container h2 span {
    font-size: 26px;
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<div id="grid">
  <div class="container">
    <h2 class="object" data-value="3">Space<br><span>Background</span></h2>
    <img src="https://i.imgur.com/5yrwyPE.png" class="object" data-value="-2" alt="">
    <img src="https://i.imgur.com/C688O6f.png" class="object" data-value="2" alt="">
    <img src="https://i.imgur.com/zQMI9zR.png" class="object" data-value="1" alt="">
    <img src="https://i.imgur.com/JSzKUzo.png" class="object" data-value="-3" alt="">
    <img src="https://i.imgur.com/dxgHvQV.png" class="object" data-value="3" alt="">
    <img src="https://i.imgur.com/kbNROja.png" class="object" data-value="-2" alt="">
    <img src="https://i.imgur.com/2Ud0NwP.png" class="object" data-value="1" alt="">
    <img src="https://i.imgur.com/c5BGOj2.png" class="object" data-value="-3" alt="">
    <img src="https://i.imgur.com/Qxs8luV.png" class="object" data-value="0" alt="">
  </div>
</div>

Это использует обратный вызов drag, который выполняется только при перетаскивании элемента (mousedown и mousemove).

0
Twisty 3 Фев 2022 в 18:58