如何移动流体div正确的距离上/下屏幕使用CSS3转换



我有一个流体容器,其中包含许多绝对定位的流体div。我想使用CSS3转换来移动这些在页面上和离开。我遇到的问题是,当使用转换时,你要么使用精确的像素量,要么使用元素本身的百分比。

所以你可以在http://jsfiddle.net/K3uPY/

上看到我所指的那种东西的例子(这只是一个测试示例)

这是使用1000%的变换来将它们移出屏幕,这显然不是一件好事,因为如果显示是巨大的,它将无法工作,这意味着每个div最终与屏幕边缘的距离不同,因此动画最终可能需要相当不同的时间来完成,这取决于它们的原始大小。

我想做的是根据视口宽度/高度(以及相关方向)将它们全部移出屏幕。

这可以很容易地通过动画顶部/左侧位置来实现,但这显然不是所有设备的最佳选择(参见http://paulirish.com/2012/why-moving-elements-with-translate-is-better-than-posabs-topleft/)

无论如何都可以使用CSS3变换甚至关键帧来做到这一点,或者我是否不得不动画左/顶部位置?

来自JSfiddle的CSS是:

html, body {height:100%; width: 100%; padding:0; margin:0;}
#wrapper {width: 100%; height: 100%; overflow: hidden;}
#container {width:50%; height: 50%; margin: auto; position: relative;}
#container div {
background-color: red;
position: absolute;
height: 25%;
-webkit-box-sizing: border-box; /* Safari/Chrome, other WebKit */
-moz-box-sizing: border-box;    /* Firefox, other Gecko */
box-sizing: border-box;         /* Opera/IE 8+ */
border: 2px solid #000000;
-webkit-transition-duration: 600ms;
-moz-transition-duration: 600ms;
-o-transition-duration: 600ms;
    transition-duration: 600ms;
    cursor: pointer;
}
.zoomleft {
-webkit-transform:translate(-1000%);
-moz-transform:translate(-1000%);
-ms-transform:translate(-1000%);
-o-transform:translate(-1000%);
    transform:translate(-1000%);
}
.zoomright {
-webkit-transform:translate(1000%);
-moz-transform:translate(1000%);
-ms-transform:translate(1000%);
 -o-transform:translate(1000%);
    transform:translate(1000%);
}
.zoomtop {
-webkit-transform:translate(0, -1000%);
-moz-transform:translate(0, -1000%);
-ms-transform:translate(0, -1000%);
 -o-transform:translate(0, -1000%);
    transform:translate(0, -1000%);
}
.zoombottom {
-webkit-transform:translate(0, 1000%);
-moz-transform:translate(0, 1000%);
-ms-transform:translate(0, 1000%);
 -o-transform:translate(0, 1000%);
    transform:translate(0, 1000%);
}
div.d1 {
width: 50%;
top: 0;
left: 0;
}
div.d2 {
width: 50%;
top: 0;
left: 50%;
}
div.d3 {
width: 25%;
top: 25%;
left: 0;
}
div.d4 {
width: 25%;
top: 25%;
left: 25%;
}
div.d5 {
width: 25%;
top: 25%;
left: 50%;
}
div.d6 {
width: 25%;
top: 25%;
left: 75%;
}
div.d7 {
width: 50%;
top: 50%;
left: 0;
}
div.d8 {
width: 50%;
top: 50%;
left: 50%;
}
div.d9 {
width: 50%;
top: 75%;
left: 0;
}
div.d10 {
width: 50%;
top: 75%;
left: 50%;
}

谢谢大家,戴夫

幸运的是,由于根据视口一切都是流动的,您仍然可以在转换中使用百分比。看我的小提琴- http://jsfiddle.net/K3uPY/23/

我必须改变的一件事是确保#container在绝对中心。我还大大简化了JS,并将所有的定位都移到了CSS中。

HTML

<div id="wrapper">
    <button id="movebtn">Move</button>
    <div id="container">
        <div class="box d1 active">1</div>
        <div class="box d2 active">2</div>
        <div class="box d3 active">3</div>
        <div class="box d4 active">4</div>
        <div class="box d5 active">5</div>
        <div class="box d6 active">6</div>
        <div class="box d7 active">7</div>
        <div class="box d8 active">8</div>
        <div class="box d9 active">9</div>
        <div class="box d10 active">10</div>
    </div>
</div>
JAVASCRIPT

$( "#movebtn" ).on('click', function() {
    $('.box').toggleClass('active');
});
CSS

html,
body {
    height:100%;
    margin:0;
    overflow: hidden;
    width: 100%;
}
#wrapper {
    height: 100%;
    overflow: hidden;
    width: 100%;
}
#container {
    width: 50%;
    height: 50%;
    margin: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.box {
  background-color: red;
  border: 2px solid #000000;
  box-sizing: border-box;
  cursor: pointer;
  height: 25%;
  position: absolute;
  transition-duration: 600ms;
}
.box.active {
  transform: none;
}

.d1 {
  width: 50%;
  top: 0;
  left: 0;
  transform: translateY(-300%);
}
.d2 {
  width: 50%;
  top: 0;
  left: 50%;
  transform: translateY(-300%);
}

.d3 {
    width: 25%;
    top: 25%;
    left: 0;
    transform: translateX(-300%);
}
.d4 {
    width: 25%;
    top: 25%;
    left: 25%;
    transform: translateX(-400%);
}
.d5 {
    width: 25%;
    top: 25%;
    left: 50%;
    transform: translateX(400%);
}
.d6 {
    width: 25%;
    top: 25%;
    left: 75%;
    transform: translateX(300%);
}

.d7 {
    width: 50%;
    top: 50%;
    left: 0;
    transform: translateX(-200%);
}
.d8 {
    width: 50%;
    top: 50%;
    left: 50%;
    transform: translateX(200%);
}

.d9 {
    width: 50%;
    top: 75%;
    left: 0;
    transform: translateY(300%);
}
.d10 {
    width: 50%;
    top: 75%;
    left: 50%;
    transform: translateY(300%);
}

相关内容

  • 没有找到相关文章

最新更新