gpt4 book ai didi

css - 如何使用 CSS3 变换将流体 divs 移动到屏幕上/屏幕外的正确距离?

转载 作者:太空宇宙 更新时间:2023-11-03 23:34:43 27 4
gpt4 key购买 nike

我有一个流体容器,其中包含许多绝对定位的流体 div。我想使用 CSS3 转换将它们移入和移出页面。我遇到的问题是,在使用转换时,您要么使用精确的像素数量,要么使用元素本身的百分比。

所以你可以在 http://jsfiddle.net/K3uPY/ 看到我所指的那种事情的例子(这只是一个测试例子)

这是使用 1000% 的变换将它们移到屏幕外,这显然不是一件好事,因为如果显示器很大,它就无法工作,这意味着每个 div 最终离开屏幕边缘的距离不同因此动画最终可能会花费完全不同的时间来完成,具体取决于它们的原始大小。

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

这可以通过动画顶部/左侧位置轻松完成,但这显然不是所有设备上的最佳选择(参见 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%;
}

谢谢大家,

戴夫

最佳答案

幸运的是,根据视口(viewport),一切都是流动的,您仍然可以在变换中使用百分比。看我的 fiddle - 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%);
}

关于css - 如何使用 CSS3 变换将流体 divs 移动到屏幕上/屏幕外的正确距离?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24434593/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com