Deslizar da direita para a esquerda?

Como posso ter um div ir de colapso para expandido (e vice-versa), mas fazê-lo da direita para a esquerda?

A maior parte do que vejo lá fora é sempre da esquerda para a direita.

Author: Ryan Montgomery, 2009-02-27

16 answers

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

Referência: https://api.jquery.com/animate/

 385
Author: JQGeek, 2015-10-19 14:55:57

Isto pode ser conseguido nativamente usando os métodos jQueryUI hide/show. Exemplo.

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

Referência: http://docs.jquery.com/UI/Effects/Slide

 243
Author: EnGassa, 2012-02-14 17:27:29

Usa isto:

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

Demonstração ao vivo

versão Melhorada

Foi adicionado algum código à demo, para evitar margem dupla com duplo-click: http://jsfiddle.net/XNnHC/942/

Use-o com facilidade;)

Http://jsfiddle.net/XNnHC/1591/

  • Códigos de JavaScript extra removidos.

  • Nomes das classes & alguns códigos CSS alterados

  • Recurso adicionado para descobrir se é expandido ou colapsou

  • Alterado se o efeito de atenuação da utilização ou não

  • Velocidade de animação alterada

Http://jsfiddle.net/XNnHC/1808/

 77
Author: h0mayun, 2016-11-20 11:59:30

Dê uma olhada em este exemplo de trabalho em Fiddle, que usa jQuery UI . É uma solução que eu usei originalmente da esquerda para a direita, mas eu mudei para trabalhar da direita para a esquerda.

Permite ao utilizador clicar rapidamente nos links sem quebrar a animação entre os painéis disponíveis.

O código de JavaScript é simples:

$(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;
    });
});

Obter HTML e CSS no Fiddle link.

Fundo branco adicionado e enchimento esquerdo apenas para melhor efeito apresentacao.

 22
Author: Erwin Julius, 2016-11-20 12:02:05

Utilize Este

<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>
 19
Author: Shwet, 2018-09-05 13:29:21
$(function() {
  $('.button').click(function() {
    $(this).toggleClass('active');
    $('.yourclass').toggle("slide", {direction: "right"}, 1000);
  });
});
 10
Author: Hil, 2017-05-07 12:09:22

Eu fiz assim:

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

Note, que o nó "btn "deve ser escondido antes da animação, e você também pode precisar de definir" posição: absoluta " para ele.

 7
Author: AbstractVoid, 2012-05-10 11:20:45
Outra biblioteca que vale a pena mencionar é animada.CSS . Ele funciona muito bem com jQuery, e você pode fazer um monte de animações interessantes, simplesmente comutando classes CSS. Gosto..
$("#Slide").alternancia().toggleClass ('bounceinleft animado');
 6
Author: Soichi Hayashi, 2016-11-11 15:25:24

Ou pode utilizar

$('#myDiv').toggle("slide:right");
 6
Author: 6563cc10d2, 2019-08-27 23:12:10

Plataforma de animação GreenSock (GSAP)) com TweenLite / TweenMax fornece transições muito mais suaves com uma personalização muito maior do que as transições jQuery ou CSS3. A fim de animar as propriedades CSS com TweenLite / TweenMax, você também vai precisar de seu plugin chamado "CSSPlugin". O TweenMax inclui isto automaticamente.

Primeiro, carrega a Biblioteca TweenMax.:

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

Ou a versão leve, 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>

Então, liga. a sua animação:

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

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

Você também pode chamá-lo com um selector de ID:

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

Se você tem jQuery carregado, você pode usar um amplo selector mais avançado, como todos os elementos que contêm uma classe específica:

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

Para mais informações, consultar:: Documentação Do TweenLite

De acordo com o seu sítio Web: O TweenLite é uma ferramenta de animação extremamente rápida, leve e flexível, que serve de base à Plataforma de animação GreenSock (GSAP)."

 5
Author: TetraDev, 2015-11-05 18:16:40

Você pode definir primeiro a largura do elemento como 0, flutuando à direita, e então no evento que você está prestes a mostrar.. seria como

$('#the_element_to_slide_from_right_left').animate({ width:'your desired width' }, 600);
Tão simples quanto isso.
 4
Author: Teody C. Seguin, 2013-05-30 07:37:58

Um exemplo de animação da direita para a esquerda sem jQuery UI , apenas com jQuery (qualquer versão, veja 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>
 4
Author: fremail, 2016-05-27 15:45:53
Veja aqui o exemplo.
$("#slider").animate({width:'toggle'});

Https://jsfiddle.net/q1pdgn96/2/

 4
Author: rafaelferreir4, 2016-07-22 22:25:00

Um exemplo feito por mim usando o scroll (apenas HTML, CSS e JS, apenas com a biblioteca jquery). Quando descer um botão desliza para a esquerda.

{[[2]}também, eu sugiro que você se o único que você quer é este efeito, não use jQuery UI porque é muito pesado(se você só quer usá-lo para isso).
$(window).scroll(function(){
  if ($(this).scrollTop() > 100) {
          event.preventDefault();
          $(".scrollToTop").css({'transform': 'translate(0px, 0px)'});
      } else {
          $(".scrollToTop").css({'transform': 'translate(40px, 0px)'});
      }
  });

Verifique este exemplo

 2
Author: Jordi Vicens, 2017-10-31 15:54:29

Se o seu div está absolutamente posicionado e sabe a largura, pode usar apenas:

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

$('#myDiv').animate({left:'-200'},1000);
Que irá deslizar para fora do ecrã.

Em alternativa, pode embrulhá - lo num contentor 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);
 1
Author: freeworlder, 2018-06-14 16:07:32
Encontrei um problema semelhante ao tentar codificar um menu para pequenos tamanhos de ecrã. A solução que eu escolhi foi tirá-la do viewport.

Eu fiz isso usando SASS e JQuery( sem jQuery UI), mas tudo isso poderia ser alcançado em JS nativos e 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>
 0
Author: DumperJumper, 2021-01-08 19:44:59