1

我正在使用 deck.js 进行演示。对于一张幻灯片,我想要一个带有数字/图像的静态标题,我可以轮播浏览。这是相关的HTML:

<section class="carousel slide">
  <h2>Static Title</h2>
  <figure class="slide"><figcaption>Text for first image</figcaption><img src="images/first_image.png" alt=""></figure>
  <figure class="slide"><figcaption>Text for second image</figcaption><img src="images/second_image.png" alt=""></figure>
  <figure class="slide"><figcaption>Text for third image</figcaption><img src="images/third_image.png" alt=""></figure> 
</section>

这是我添加到deck.js 中的JS,以使其与deck.js 附带的水平滑动主题一起工作。

.carousel .deck-before {
    -webkit-transform: translate3d(-400%, 0, 0);
    -moz-transform: translate(-400%, 0);
    -ms-transform: translate(-400%, 0);
    -o-transform: translate(-400%, 0);
    transform: translate3d(-400%, 0, 0);
    height:0;
}

.carousel .deck-after {
    -webkit-transform: translate3d(400%, 0, 0);
    -moz-transform: translate(400%, 0);
    -ms-transform: translate(400%, 0);
    -o-transform: translate(400%, 0);
    transform: translate3d(400%, 0, 0);
    height:0;
}

.carousel .deck-next {
    -webkit-transform: translate3d(200%, 0, 0);
    -moz-transform: translate(200%, 0);
    -ms-transform: translate(200%, 0);
    -o-transform: translate(200%, 0);
    transform: translate3d(200%, 0, 0);
    height:0;
}

.carousel .deck-previous {
    -webkit-transform: translate3d(-200%, 0, 0);
    -moz-transform: translate(-200%, 0);
    -ms-transform: translate(-200%, 0);
    -o-transform: translate(-200%, 0);
    transform: translate3d(-200%, 0, 0);
    height:0;
}

当图像的轮播正在前进时,这非常有用。但是,当我返回时,移出屏幕的图像会向下移动,因此它位于新图像进入的位置下方。

如何使从屏幕右侧移出的图像与从左侧出现在屏幕上的图像保持水平?

4

1 回答 1

1

问题的根源在于height没有过渡的事实,因此在类更改发生的那一刻,前一个元素立即具有高度,向下推仍未过渡到视野之外的幻灯片。

这是一个相当难以解决的问题。您需要根据自己的需要做出一些选择。

首先,height:0从你的每一个之前/之后/上一个/下一个中取出,然后说.carousel .slide { height: 0 }.

你需要deck.scale 扩展来工作,还是轮播后有幻灯片内容?如果是这样,你需要给出.carousel一个高度来补偿。

你事先知道那个高度吗?只需在 CSS 中设置即可。

不知道高度,或者只是想到处使用这个而不必每次都手动设置高度?编写一个检查轮播内容并设置高度的小脚本。像这样的东西(未经测试,当心):

$(window).load(function() {
  $('.carousel').each(function(carousel) {
    var $carousel = $(carousel);
    var maxHeight = 0;

    $carousel.each(function() {
      var height = $(this).height();
      maxHeight = Math.max(height, maxHeight);
    });

    $carousel.height(maxHeight);
  });
});

使用这样的脚本,请务必height:0从 CSS 中完全删除声明。

于 2012-07-28T00:55:18.150 回答