使用CSS,如何应用多个转换?
示例:在以下示例中,仅应用平移,而不应用旋转。
li:nth-child(2) {
transform: rotate(15deg);
transform: translate(-20px,0px);
}
使用CSS,如何应用多个转换?
示例:在以下示例中,仅应用平移,而不应用旋转。
li:nth-child(2) {
transform: rotate(15deg);
transform: translate(-20px,0px);
}
当前回答
这是一个老问题,但最近发现与我非常相关。我发现“transform:metrix(..)”更方便使用。因此,对于所讨论的问题,下面的示例在x轴上应用约15度旋转和向右平移20px(为了方便)。
.matrix转换{变换原点:左上;变换:矩阵(0.965,0.258,-0.258,0.965,20,0);字体大小:30px;}.组合变换{变换原点:左上;变换:旋转(15度)平移X(20像素);字体大小:30px;}<div class=matrixTransform>A</div><div class=combindTransform>B</div>
根据我收集的数据,这个特定的变换使用初始的4个参数来表示变换,例如缩放、旋转。并且似乎是按行和列的顺序排列的。其余两个分别是x轴和y轴上的平移。我发现Wolfram Alpha备忘单(计算器)非常有用。
其他回答
从这里开始,在CSS中,若您重复2个或更多值,则始终应用最后一个值,除非使用!重要的标签,但同时避免使用!尽可能重要,所以在你的情况下这就是问题所在,所以在这种情况下,第二个变换会覆盖第一个变换。。。
那你怎么能做你想做的?。。。
别担心,转换同时接受多个值。。。因此,下面的代码将起作用:
li:nth-child(2) {
transform: rotate(15deg) translate(-20px, 0px); //multiple
}
如果您想玩变换,请从下面的MDN运行iframe:<iframe src=“https://interactive-examples.mdn.mozilla.net/pages/css/transform.html“class=”interactive“width=”100%“frameborder=”0“height=”250“></iframe>
查看下面的链接了解更多信息:
<<CSS转换>>
在单行css中转换旋转和平移:-如何?
div.className{变换:旋转(270度)平移(-50%,0);-webkit转换:旋转(270度)平移(-50%,-50%);-moz变换:旋转(270度)平移(-50%,-50%);-ms变换:旋转(270度)平移(-50%,-50%);-o变换:旋转(270度)平移(-50%,-50%);浮动:左侧;位置:绝对;顶部:50%;左:50%;}<html><head></head><body><div class=“className”><span style=“font-size:50px”>A</span></div></body></html>
我学到的教训。
如果您使用的是样式的React css,请不要包含分号,即使是在它的末尾,因为它是由React自动内部包含的。
就像:
style={
transform: "rotate(90deg) scaleX(-1)",
}
这是一个老问题,但最近发现与我非常相关。我发现“transform:metrix(..)”更方便使用。因此,对于所讨论的问题,下面的示例在x轴上应用约15度旋转和向右平移20px(为了方便)。
.matrix转换{变换原点:左上;变换:矩阵(0.965,0.258,-0.258,0.965,20,0);字体大小:30px;}.组合变换{变换原点:左上;变换:旋转(15度)平移X(20像素);字体大小:30px;}<div class=matrixTransform>A</div><div class=combindTransform>B</div>
根据我收集的数据,这个特定的变换使用初始的4个参数来表示变换,例如缩放、旋转。并且似乎是按行和列的顺序排列的。其余两个分别是x轴和y轴上的平移。我发现Wolfram Alpha备忘单(计算器)非常有用。
将来的某个时候,(现在可用,请参阅下面的更新)我们可以这样写:
li:nth-child(2) {
rotate: 15deg;
translate:-20px 0px;
}
当在元素上应用单个类时,这将变得特别有用:
<div class="teaser important"></div>
.teaser{rotate:10deg;}
.important{scale:1.5 1.5;}
该语法在进行中的CSS Transforms Level 2规范中定义,但除了chrome canary之外,找不到任何关于当前浏览器支持的内容。希望有一天我会回来更新浏览器支持;)
在本文中找到了有关当前浏览器的变通方法的信息,您可能希望查看这些信息。
更新:功能已在firefox72中
更新:现已推出chrome 104、edge 104、safari 14.1,请参见https://web.dev/css-individual-transform-properties/#:~:text=支持%20这些%20属性。-,浏览器%20支持,-%3A