Переместить div справа налево с помощью CSS-перехода - PullRequest
0 голосов
/ 26 апреля 2019

Я работаю над выдвижным ящиком, в котором мне нужно перемещать div слева направо при нажатии кнопки.Я пытаюсь сделать это с помощью CSS-переходов и jQuery, но это не работает.Вот то, что я пробовал до сих пор:

$(document).ready(function() {
  $(".openUserEditBox").on("click", function() {
    $(".user-drawer").show();
  });
});
.user-drawer {
  position: relative;
  width: 600px;
  top: 50px;
  background-color: #f2f2f2;
  border: 1px solid #bbbbbb;
  min-height: 450px;
  float: right;
  display: none;
  left: 100px;
  transition: left 1s ease-in-out;
}

.user-menu {
  padding: 10px 20px;
  position: absolute;
}

.btn-default {
  background-color: #fff;
  padding: 10px;
  border: 1px solid #bbbbbb;
  width: 150px;
}

.btn-default:hover {
  cursor: pointer;
  box-shadow: inset 0 1px 3px 0 #bbbbbb;
}

.btngroup {
  float: right
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="btngroup">
  <button class="btn-default openUserEditBox">Show Drawer</button>
  <button class="btn-default closeUserEditBox">Hide Drawer</button>
</div>
<div class="userForm">
  <div class="user-drawer">
    <div class="user-menu">
      <h1>Edit User</h1>
    </div>
  </div>
</div>

Ответы [ 3 ]

1 голос
/ 26 апреля 2019

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

$('.openUserEditBox').click(function() {
    $(".userForm").removeClass("hide");
    $(".userForm").addClass("show");
});
$('.closeUserEditBox').click(function() {
    $(".userForm").removeClass("show");
    $(".userForm").addClass("hide");
});
* {
    box-sizing: border-box;
    position: relative;
}

body {
    overflow: hidden;
}

.user-drawer {
    position: relative;
    width: 600px;
    top: 50px;
    background-color: #f2f2f2;
    border: 1px solid #bbbbbb;
    min-height: 450px;
}

.user-drawer .active {
    left: 20px;
    transform: translateX(0%);
}

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

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

.user-menu {
    padding: 10px 20px;
    position: absolute;
}

.btn-default {
    background-color: #fff;
    padding: 10px;
    border: 1px solid #bbbbbb;
    width: 150px;
}

.btn-default:hover {
    cursor: pointer;
    box-shadow: inset 0 1px 3px 0 #bbbbbb;
}

.btngroup {
    text-align: right
}

.userForm {
    position: absolute;
    right: -100%;
    visibility: visible;
    transition: 0.6s;
}

.userForm.show {
    visibility: visible;
    right: 0;
}

.userForm.hide {
    visibility: hidden;
    right: -100%;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="btngroup">
    <button class="btn-default openUserEditBox">Show Drawer</button>
    <button class="btn-default closeUserEditBox">Hide Drawer</button>
</div>
<div class="userForm">
    <div class="user-drawer">
        <div class="user-menu">
            <h1>Edit User</h1>
        </div>
    </div>
</div>
1 голос
/ 26 апреля 2019

Если вы хотите передать свойство left, вы не можете использовать show() и hide().Просто установите свойство left в JavaScript.

$(document).ready(function() {
  $(".openUserEditBox").on("click", function() {
    $(".user-drawer")[0].style.left = '0';
  });
  $(".closeUserEditBox").on("click", function() {
    $(".user-drawer")[0].style.left = '602px';
  });
});
.userForm {
  overflow-x: hidden;
}

.user-drawer {
  position: relative;
  width: 600px;
  background-color: #f2f2f2;
  border: 1px solid #bbbbbb;
  min-height: 450px;
  margin-left:auto;
  left: 602px;
  transition:left 1s;
}

.btn-default {
  background-color: #fff;
  padding: 10px;
  border: 1px solid #bbbbbb;
  width: 150px;
}

.btngroup {
  text-align:right;
  margin:8px 0;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="btngroup">
  <button class="btn-default openUserEditBox">Show Drawer</button>
  <button class="btn-default closeUserEditBox">Hide Drawer</button>
</div>
<div class="userForm">
  <div class="user-drawer">
    <div class="user-menu">
      <h1>Edit User</h1>
    </div>
  </div>
</div>

Обратите внимание, что я обошелся без поплавков, так как они помешали overflow в пользовательской форме.Надеюсь, что он все еще пригоден для использования в его нынешнем виде.

0 голосов
/ 26 апреля 2019

Вы можете сделать это, добавив класс и удалив его по клику и установив на нем анимацию

$(document).ready(function() {
  $(".openUserEditBox").on("click", function() {
       $(".user-drawer").removeClass("slide-out");
       $(".user-drawer").addClass("slide-in");
  });
  $(".closeUserEditBox").on("click", function() {
       $(".user-drawer").removeClass("slide-in");
       $(".user-drawer").addClass("slide-out");
  });
});
.userForm {
  overflow-x: hidden;
}

.user-drawer {
  position: relative;
  width: 600px;
  background-color: #f2f2f2;
  border: 1px solid #bbbbbb;
  min-height: 450px;
  margin-left:auto;
  left: 100%;
}

.btn-default {
  background-color: #fff;
  padding: 10px;
  border: 1px solid #bbbbbb;
  width: 150px;
}

.btngroup {
  text-align:right;
  margin:8px 0;
}

.slide-in {
  animation: slide-in 0.5s forwards;
  -webkit-animation: slide-in 0.5s forwards;
}
.slide-out {
  animation: slide-out 0.5s forwards;
  -webkit-animation: slide-out 0.5s forwards;
}
@-webkit-keyframes slide-in {
  100% {
    left: 0;
  }
}
@keyframes slide-in {
  100% {
    left: 0;
  }
}
@-webkit-keyframes slide-out {
  0% {
    left: 0;
  }
  100% {
    left: 100%;
  }
}
@keyframes slide-out {
  0% {
    left: 0;
  }
  100% {
    left:100%;
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="btngroup">
  <button class="btn-default openUserEditBox">Show Drawer</button>
  <button class="btn-default closeUserEditBox">Hide Drawer</button>
</div>
<div class="userForm">
  <div class="user-drawer">
    <div class="user-menu">
      <h1>Edit User</h1>
    </div>
  </div>
</div>
...