Como posso fazer com que uma div passe de recolhida para expandida (e vice-versa), mas da direita para a esquerda?
Quase tudo o que vejo lá fora é sempre da esquerda para a direita.
Como posso fazer com que uma div passe de recolhida para expandida (e vice-versa), mas da direita para a esquerda?
Quase tudo o que vejo lá fora é sempre da esquerda para a direita.
Respostas:
$("#slide").animate({width:'toggle'},350);
Referência: https://api.jquery.com/animate/
paddingLeft: 'toggle', paddingRight: 'toggle'
quando o elemento tiver preenchimento interno.
CSS
para olhar como um slide verdadeira esquerda
overflow: hidden
.
Isso pode ser conseguido nativamente usando os métodos hide / show do jQueryUI. Por 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
Usa isto:
$('#pollSlider-button').animate({"margin-right": '+=200'});
Versão melhorada
Algum código foi adicionado à demonstração, para evitar margem dupla em clique duplo: http://jsfiddle.net/XNnHC/942/
Use-o com facilidade;)
http://jsfiddle.net/XNnHC/1591/
Códigos JavaScript extras removidos.
Nomes de classe e alguns códigos CSS alterados
Adicionado recurso para descobrir se está expandido ou recolhido
Alterado se usa o efeito de atenuação ou não
Velocidade de animação alterada
Dê uma olhada neste exemplo de trabalho no Fiddle, que usa a jQuery UI . É uma solução que usei originalmente da esquerda para a direita, mas a alterei para funcionar da direita para a esquerda.
Ele permite que o usuário clique nos links rapidamente, sem interromper a animação entre os painéis disponíveis.
O código 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;
});
});
Obtenha HTML e CSS no link Fiddle.
Adicionado fundo branco e preenchimento à esquerda apenas para uma melhor apresentação do efeito.
Usa isto
<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>
Eu fiz desta maneira:
var btn_width = btn.width();
btn.width(0);
btn.show().animate({width: btn_width}, {duration: 500});
Observe que o nó "btn" deve estar oculto antes da animação, e também pode ser necessário definir "position: absolute" para ele.
width: 'toggle'
? btn.show().animate({width: 'toggle'}, {duration: 500});
é tudo que você precisa, acredito.
Outra biblioteca que vale a pena mencionar é o animate.css . Funciona muito bem com o jQuery, e você pode fazer muitas animações interessantes simplesmente alternando as classes CSS.
Gostar..
$ ("# slide"). toggle (). toggleClass ('animação bounceInLeft');
A GreenSock Animation Platform (GSAP) comTweenLite
/TweenMax
fornece transições muito mais suaves com uma personalização muito maior do que as transições jQuery ou CSS3. Para animar propriedades CSS com TweenLite / TweenMax, você também precisará do plug-in chamado "CSSPlugin". O TweenMax inclui isso automaticamente.
Primeiro, carregue 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>
Em seguida, chame 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 seletor de ID:
TweenLite.to("#myID", .7, { x: 500, ease: Power3.easeOut});
Se você tiver o jQuery carregado, poderá usar seletores gerais mais avançados, 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 obter detalhes completos, consulte: Documentação do TweenLite
De acordo com o site: "O TweenLite é uma ferramenta de animação extremamente rápida, leve e flexível que serve como base da GreenSock Animation Platform (GSAP)".
Você pode definir primeiro a largura do elemento como 0, flutuando para a direita e depois no evento que você está prestes a mostrá-lo.
$('#the_element_to_slide_from_right_left').animate({ width:'your desired width' }, 600);
Simples assim.
Um exemplo de animação da direita para a esquerda sem a interface do usuário do jQuery , apenas com o jQuery (qualquer versão, consulte 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>
ou você pode usar
$('#myDiv').toggle("slide:right");
Um exemplo feito por mim usando o scroll (apenas HTML, CSS e JS, apenas com a biblioteca jquery). Quando rola para baixo, um botão desliza para a esquerda.
Além disso, sugiro que se o único que você deseja é esse efeito, não use a interface do jQuery porque é muito pesada (se você quiser usá-la apenas para isso).
$(window).scroll(function(){
if ($(this).scrollTop() > 100) {
event.preventDefault();
$(".scrollToTop").css({'transform': 'translate(0px, 0px)'});
} else {
$(".scrollToTop").css({'transform': 'translate(40px, 0px)'});
}
});
Veja este exemplo
Se você div
está absolutamente posicionado e você conhece a largura, basta usar:
#myDiv{
position:absolute;
left: 0;
width: 200px;
}
$('#myDiv').animate({left:'-200'},1000);
O que o deslizará para fora da tela.
Como alternativa, você pode envolver um contêiner 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);