Сдвинуть справа налево?

Как я могу сделать так, чтобы div переходил из свернутого в развернутый (и наоборот), но делать это справа налево?

Почти все, что я вижу, всегда слева направо.


person Ryan Montgomery    schedule 27.02.2009    source источник
comment
например jsfiddle.net/DcWS2/10   -  person Stano    schedule 22.05.2013
comment
связанные: stackoverflow.com/questions/521291/jquery-slide -лева-и-показать   -  person Timo Huovinen    schedule 24.02.2014


Ответы (16)


$("#slide").animate({width:'toggle'},350);

Ссылка: https://api.jquery.com/animate/

person JQGeek    schedule 05.03.2009
comment
Вы также можете добавить paddingLeft: 'toggle', paddingRight: 'toggle', если у элемента есть внутренние отступы. - person piotr_cz; 06.05.2016
comment
Работает нормально, только скользит слева направо, когда я пробую. Можно ли сделать наоборот? - person twan; 20.05.2016
comment
Единственная проблема заключается в том, что если внутри есть контент, он сжимает его по горизонтали, заставляя элементы управления перемещаться / изменять размер / переносить и т. Д. Есть ли для этого хорошее решение? - person Neil Barnwell; 16.05.2017
comment
Вашему коду нужно больше CSS, чтобы он выглядел как настоящий слайд слева - person AmerllicA; 23.09.2017
comment
медленный и запаздывающий на мобильном телефоне - person Luvias; 01.02.2018
comment
Он несовместим со старыми браузерами - person Sveen; 21.03.2018
comment
@NeilBarnwell, если можете, поместите содержимое в оболочку фиксированной ширины и получите overflow: hidden контейнера. - person Ben Philipp; 12.10.2018

Это может быть достигнуто изначально с помощью методов jQueryUI hide / show. Например.

    // To slide something leftwards into view,
    // with a delay of 1000 msec
    $("div").click(function () {
          $(this).show("slide", { direction: "left" }, 1000);
    });

Ссылка: http://docs.jquery.com/UI/Effects/Slide

person EnGassa    schedule 14.02.2012
comment
@ekerner - для этого требуется JQueryUI, огромная библиотека. Если все, что вам нужно, это простой переход между слайдами, это, вероятно, не ответ;) - person Jesse; 10.11.2012
comment
Это лучший способ, если у вас установлен jQueryUI. - person steampowered; 14.11.2012
comment
Для уточнения - минимальный размер файла не менее 235кб !! Это хорошо, но, как отмечает @Jesse, значительно улучшит вашу страницу. - person Ukuser32; 23.02.2016
comment
Используя пользовательского конструктора и удалив все, кроме анимации слайдов, возможно получить минифицированный JS до 20 КБ. - person Skylar Ittner; 29.06.2017
comment
Я бы хотел, чтобы в документации JQuery UI были такие примеры. Спасибо - person andreszs; 08.04.2018

Использовать этот:

$('#pollSlider-button').animate({"margin-right": '+=200'});

Живая демонстрация

Улучшенная версия

В демонстрацию был добавлен некоторый код для предотвращения двойного поля при двойном щелчке: http://jsfiddle.net/XNnHC/942/

Используйте это с ослаблением;)

http://jsfiddle.net/XNnHC/1591/

  • Удалены лишние коды JavaScript.

  • Имена классов и некоторые коды CSS изменены

  • Добавлена ​​возможность узнать, развернуто или свернуто

  • Изменен, использовать ли эффект ослабления или нет

  • Изменена скорость анимации

http://jsfiddle.net/XNnHC/1808/

person h0mayun    schedule 15.12.2012
comment
Вычисляет значения в пикселях, поэтому для "%" невозможно. - person Faisal Ashfaq; 28.07.2015
comment
он перемещается влево при каждом щелчке. - person Elyor; 05.09.2015
comment
Вы можете проверить внешнюю ширину и использовать ее для добавления правого поля. - person Tofandel; 10.10.2019

Взгляните на этот рабочий пример на Fiddle, в котором используется jQuery UI. Это решение, которое я использовал изначально слева направо, но я изменил его так, чтобы он работал справа налево.

Это позволяет пользователю быстро переходить по ссылкам, не прерывая анимацию доступных панелей.

Код JavaScript прост:

$(document).ready(function(){
    // Mostra e nascondi view-news
    var active = "europa-view";
    $('a.view-list-item').click(function () {
        var divname= this.name;
        $("#"+active ).hide("slide", { direction: "right" }, 1200);
        $("#"+divname).delay(400).show("slide", { direction: "right" }, 1200);
        active = divname;
    });
});

Получите HTML и CSS по ссылке Fiddle.

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

person Erwin Julius    schedule 10.01.2013
comment
да. Это указано в приведенной в качестве примера ссылке [jsfiddle.net/erwinjulius/az4JL/] - person Erwin Julius; 25.06.2013

Использовать этот

<script src="jquery.min.js"></script>
<script src="jquery-ui.min.js"></script>
<script>
    $(document).ready(function(){
        $("#flip").click(function () {
            $("#left_panel").toggle("slide", { direction: "left" }, 1000);
        });
    });
</script>
person Shwet    schedule 31.12.2012
comment
Да, вам нужен интерфейс jQuery для расширенных параметров замедления - person zanderwar; 28.10.2016

Я сделал это так:

var btn_width = btn.width();
btn.width(0);
btn.show().animate({width: btn_width}, {duration: 500});

Обратите внимание, что узел «btn» должен быть скрыт перед анимацией, и вам также может потребоваться установить для него «position: absolute».

person AbstractVoid    schedule 10.05.2012
comment
Почему бы не использовать width: 'toggle'? Думаю, btn.show().animate({width: 'toggle'}, {duration: 500}); - это все, что вам нужно. - person Aart den Braber; 12.05.2015

Еще одна заслуживающая упоминания библиотека - animate.css. Он отлично работает с jQuery, и вы можете делать много интересных анимаций, просто переключая классы CSS.

Нравиться..

$ ("# слайд"). toggle (). toggleClass ('анимированный bounceInLeft');

person Soichi Hayashi    schedule 11.11.2016

или вы можете использовать

$('#myDiv').toggle("slide:right");
person 6563cc10d2    schedule 27.08.2019
comment
Отвечая на вопрос десятилетней давности четырнадцатью другими существующими ответами, это поможет объяснить, какой новый подход дает ваш ответ, и был ли он действителен, когда вопрос был задан, или используются ли методы, которые стали доступны в течение этих десяти лет. . - person Jason Aller; 28.08.2019
comment
@JasonAller Почему? - person groovenectar; 29.10.2020
comment
@groovenectar, ответ на этот вопрос - длинное эссе, которое здесь не подходит и здесь не по теме. Я предлагаю вам спросить об этом на мета, где может состояться полноценное обсуждение. - person Jason Aller; 29.10.2020
comment
@JasonAller, новые ответы на старые вопросы очень часто оказываются самыми ценными. Так что я надеюсь, что люди продолжат делать это, не отговариваясь от участия в StackExchange. Из-за ценности для этого подход должен быть обновлением SE, например повторная публикация вопроса с помощью модератора и т.д. - person groovenectar; 30.10.2020
comment
@groovenectar, пожалуйста, покажите мне, где в моем комментарии я не рекомендовал добавлять новый ответ на старый вопрос? Ответ только на код, отброшенный на старый вопрос, не так полезен, как тот, в котором есть и код, и объяснение. - person Jason Aller; 30.10.2020

Платформа анимации GreenSock (GSAP) с TweenLite / TweenMax обеспечивает более плавные переходы с гораздо большей степенью настройки чем переходы jQuery или CSS3. Чтобы анимировать свойства CSS с помощью TweenLite / TweenMax, вам также понадобится их плагин под названием «CSSPlugin». TweenMax включает это автоматически.

Сначала загрузите библиотеку TweenMax:

<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.0/TweenMax.min.js"></script>

Или облегченная версия TweenLite:

<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.0/plugins/CSSPlugin.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.0/easing/EasePack.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.0/TweenLite.min.js"></script>

Затем вызовите анимацию:

 var myObj= document.getElementById("myDiv");

// Syntax: (target, speed, {distance, ease})
 TweenLite.to(myObj, .7, { x: 500, ease: Power3.easeOut});

Вы также можете вызвать его с помощью селектора идентификатора:

 TweenLite.to("#myID", .7, { x: 500, ease: Power3.easeOut});

Если у вас загружен jQuery, вы можете использовать более продвинутые широкие селекторы, например все элементы, содержащие определенный класс:

 // This will parse the selectors using jQuery's engine.
TweenLite.to(".myClass", .7, { x: 500, ease: Power3.easeOut});

Подробную информацию см. в документации TweenLite.

Согласно их веб-сайту: «TweenLite - чрезвычайно быстрый, легкий и гибкий инструмент анимации, который служит основой платформы анимации GreenSock (GSAP)».

person TetraDev    schedule 05.11.2015

Вы можете определить сначала ширину элемента как 0, плавающую вправо, а затем в том событии, которое вы собираетесь показать ... это будет похоже на

$('#the_element_to_slide_from_right_left').animate({ width:'your desired width' }, 600);

Просто как тот.

person Teody C. Seguin    schedule 30.05.2013

Пример анимации справа налево без jQuery UI, только с jQuery (любая версия, см. https://api.jquery.com/animate/).

$(document).ready(function() {
  var contentLastMarginLeft = 0;
  $(".wrap").click(function() {
    var box = $(".content");
    var newValue = contentLastMarginLeft;
    contentLastMarginLeft = box.css("margin-left");
    box.animate({
      "margin-left": newValue
    }, 500);
  });
});
.wrap {
  background-color: #999;
  width: 200px;
  overflow: hidden;
}
.content {
  width: 100%;
  margin-left: 100%;
  background-color: #eee;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="wrap">
  click here
  <div class="content">
    I would like to have a div go from collapsed to expanded (and vice versa), but do so from right to left. Most everything I see out there is always left to right.
  </div>
</div>

person fremail    schedule 27.05.2016

Посмотрите пример здесь.

$("#slider").animate({width:'toggle'});

https://jsfiddle.net/q1pdgn96/2/

person rafaelferreir4    schedule 22.07.2016
comment
Вы проверяли этот ответ перед тем, как опубликовать свой? - person Michael Hoff; 23.07.2016

Пример, сделанный мной с использованием прокрутки (только HTML, CSS и JS, только с библиотекой jquery). При прокрутке вниз кнопка перемещается влево.

Кроме того, я предлагаю вам, если вам нужен только этот эффект, не используйте jQuery UI, потому что он слишком тяжелый (если вы просто хотите использовать его для этого).

$(window).scroll(function(){
  if ($(this).scrollTop() > 100) {
          event.preventDefault();
          $(".scrollToTop").css({'transform': 'translate(0px, 0px)'});
      } else {
          $(".scrollToTop").css({'transform': 'translate(40px, 0px)'});
      }
  });

Проверьте этот пример

person Jordi Vicens    schedule 31.10.2017
comment
Да, переходы CSS - один из лучших способов добиться этого в настоящее время. - person Tom Tom; 22.12.2017

Если ваш div абсолютно позиционирован и вы знаете ширину, вы можете просто использовать:

#myDiv{
position:absolute;
left: 0;
width: 200px;
}

$('#myDiv').animate({left:'-200'},1000);

Что сдвинет его с экрана.

В качестве альтернативы вы можете обернуть его контейнером div

#myContainer{
position:relative;
width: 200px;
overflow: hidden;
}

#myDiv{
position:absolute;
top: 0;
left: 0;
width: 200px;
}

<div id="myContainer">

<div id="myDiv">Wheee!</div>

</div>

$('#myDiv').animate({left:'-200'},1000);
person Colin R. Turner    schedule 14.06.2018

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

Я сделал это с помощью SASS и JQuery (без пользовательского интерфейса JQuery), но все это может быть достигнуто с помощью собственного JS и CSS.

https://codepen.io/maxbethke/pen/oNzMLRa

var menuOpen = false

var init = () => {
    $(".menu__toggle, .menu__blackout").on("click", menuToggle)
}

var menuToggle = () => {
    console.log("Menu:Toggle");
    $(".menu__blackout").fadeToggle();

    if(menuOpen) { // close menu
        $(".menu__collapse").css({
            left: "-80vw",
            right: "100vw"
        });
    } else { // open menu
        $(".menu__collapse").css({
            left: "0",
            right: "20vw"
        });
    }

    menuOpen = !menuOpen;
}

$(document).ready(init);
.menu__toggle {
    position: absolute;
    right: 0;
    z-index: 1;
}

.menu__blackout {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10;
}

.menu__collapse {
  position: absolute;
  top: 0;
  right: 100vw;
  bottom: 0;
  left: -80vw;
  background: white;
  -webkit-transition: ease-in-out all 1s;
  transition: ease-in-out all 1s;
  z-index: 11;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<button class="menu__toggle">Toggle menu</button>

<menu class="menu">
  <div class="menu__blackout"></div>
  <div class="menu__collapse">
    <ul class="list">
      <li class="list__item">
        <a class="list__item__link" href="#section1">Menu Item 1</a>
      </li>
      <li class="list__item">
        <a class="list__item__link" href="#section2">Menu Item 2</a>
      </li>
      <li class="list__item">
        <a class="list__item__link" href="#section3">Menu Item 3</a>
      </li>
      <li class="list__item">
        <a class="list__item__link" href="#section4">Menu Item 4</a>
      </li>
      <li class="list__item">
        <a class="list__item__link" href="#section5">Menu Item 5</a>
      </li>
    </ul>
  </div>
</menu>

person DumperJumper    schedule 08.01.2021

person    schedule
comment
Я за комментарии, но этот код не требует пояснений. - person Jon; 12.07.2017