408

我怎样才能让一个 div 从折叠到展开(反之亦然),但从右到左这样做?

我在那里看到的大多数东西总是从左到右。

4

16 回答 16

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

参考:https ://api.jquery.com/animate/

于 2009-03-05T15:20:58.987 回答
243

这可以使用 jQueryUI 隐藏/显示方法本地实现。例如。

    // 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

于 2012-02-14T17:27:29.463 回答
77

用这个:

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

现场演示

改良版

演示中添加了一些代码,以防止双击时出现双页边距:http: //jsfiddle.net/XNnHC/942/

与缓动一起使用;)

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

  • 删除了额外的 JavaScript 代码。

  • 类名和一些 CSS 代码已更改

  • 添加了查找是否展开或折叠的功能

  • 改变是否使用缓动效果

  • 改变动画速度

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

于 2012-12-15T13:58:25.490 回答
23

看看这个使用jQuery UI的 Fiddle 上的工作示例。这是我最初从左到右使用的解决方案,但我已将其更改为从右到左工作。

它允许用户快速单击链接,而不会破坏可用面板之间的动画。

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

在 Fiddle 链接上获取 HTML 和 CSS。

添加白色背景和左填充只是为了更好的效果呈现。

于 2013-01-10T17:59:25.557 回答
20

用这个

<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>
于 2012-12-31T08:18:35.537 回答
11
$(function() {
  $('.button').click(function() {
    $(this).toggleClass('active');
    $('.yourclass').toggle("slide", {direction: "right"}, 1000);
  });
});
于 2017-05-07T12:09:22.440 回答
7

我是这样做的:

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

请注意,该节点“btn”应该在动画之前隐藏,您可能还需要为其设置“位置:绝对”。

于 2012-05-10T11:20:45.997 回答
7

或者你可以使用

$('#myDiv').toggle("slide:right");
于 2019-08-27T23:12:10.593 回答
7

另一个值得一提的库是animate.css。它与 jQuery 一起工作得很好,你可以通过切换 CSS 类来制作很多有趣的动画。

喜欢..

$("#slide").toggle().toggleClass('动画bounceInLeft');

于 2016-11-11T15:25:24.767 回答
5

带有TweenLite/的GreenSock 动画平台 (GSAP)TweenMax提供了比 jQuery 或 CSS3 过渡更平滑的过渡和更多的自定义。为了使用 TweenLite / TweenMax 为 CSS 属性设置动画,您还需要他们的名为“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});

您也可以使用 ID 选择器调用它:

 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) 的基础。”

于 2015-11-05T18:10:24.523 回答
5

一个没有 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>

于 2016-05-27T15:45:53.393 回答
4

您可以首先将元素的宽度定义为 0,向右浮动,然后在您将要显示它的事件上.. 它会像

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

就那么简单。

于 2013-05-30T07:37:58.173 回答
4

在此处查看示例。

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

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

于 2016-07-22T22:25:00.613 回答
2

我使用滚动(仅 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)'});
      }
  });

检查这个例子

于 2017-10-31T15:54:29.007 回答
1

如果您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);
于 2018-06-14T16:07:32.593 回答
0

我在尝试为小屏幕尺寸编写菜单时遇到了类似的问题。我采用的解决方案是将其从视口中推开。

我使用 SASS 和 JQuery(无 JQuery UI)制作了这个,但这都可以在原生 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>

于 2021-01-08T12:45:55.430 回答