gpt4 book ai didi

css - 如何使 flexbox 中的旋转元素固定在页面的右侧?

转载 作者:行者123 更新时间:2023-11-28 09:31:29 25 4
gpt4 key购买 nike

我想创建一个小的垂直文本“水印”背景,它在一些 reveal.js 幻灯片的右侧运行。我已经知道我需要使用 transform 来旋转任何我想要垂直运行的元素到页面右侧的长度。

问题是很多几何计算似乎发生在 转换发生之前,结果是当我尝试将元素与 flexbox 对齐时几何计算错误。这是一个几乎有效的基本示例:

div.outer {
position: fixed;
top: 0;
bottom: 0;
right: 0;
background: grey;

display: flex;
flex-flow: column nowrap;
justify-content: space-around;
}

.item {
transform: rotate(-90deg);
background: red;
}
<div class="outer">
<div class="item" style="width: 200px">
Some text
</div>
<img class="item" src="" alt="" />
</div>

问题在于外部 div 的宽度是根据非旋转 flexbox 元素的宽度计算的,因此元素显示出偏离页面。

如果我尝试通过将 align-items 更改为 flex-end 来解决此问题,结果是每个元素都对齐到不同的

div.outer {
position: fixed;
top: 0;
bottom: 0;
right: 0;
background: grey;

display: flex;
flex-flow: column nowrap;
justify-content: space-around;
align-items: flex-end;
}

.item {
transform: rotate(-90deg);
background: red;
}
<div class="outer">
<div class="item" style="width: 200px">
Some text
</div>
<img class="item" src="" alt="" />
</div>

我猜这是因为根据元素的旋转前版本计算了放置基线的位置,然后它们旋转到您在那里看到的位置。

做这样的事情的正确方法是什么?有什么方法可以创建一个元素,在旋转发生后计算关于其位置的几何计算?

最佳答案

调整transform-origin,在不改变对齐方式的情况下依赖平移

这是在左边:

div.outer {
position: fixed;
top: 0;
bottom: 0;
right: 0;
background: grey;

display: flex;
flex-flow: column nowrap;
}

.item {
transform: rotate(-90deg) translate(-100%);
transform-origin:top left;
background: red;
}
<div class="outer">
<div class="item" style="width: 200px">
Some text
</div>
<img class="item" src="" alt="" />
</div>

右边是:

div.outer {
position: fixed;
top: 0;
bottom: 0;
right: 0;
background: grey;

display: flex;
flex-flow: column nowrap;
}

.item {
transform: rotate(-90deg) translateY(-100%);
transform-origin:top right;
background: red;
}
<div class="outer">
<div class="item" style="width: 200px">
Some text
</div>
<img class="item" src="" alt="" />
</div>

关于css - 如何使 flexbox 中的旋转元素固定在页面的右侧?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50724517/

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