我对Chrome有一个奇怪的问题。
如果我创建一个带有一些透视的div
,边框半径,隐藏溢出以及元素内的转换div
将不会尊重透视。
http://codepen.io/cavax/pen/MwPgxz
如果我删除了边框半径,你可以看到元素有透视。
有什么想法吗?
<div id="prova">
<div id="rotate"></div>
</div>
<div id="prova2">
<div id="rotate2"> </div>
</div>
#prova {
width: 400px;
height: 200px;
-webkit-perspective: 400px;
perspective: 400px;
margin: 40px;
border: 1px solid #000;
overflow: hidden;
border-radius: 30px;
}
#rotate {
width: 200px;
height: 200px;
background-color: red;
-webkit-transform: rotateX(40deg);
transform: rotateX(40deg);
position: absolute;
bottom: 0px;
left: 100px;
}
#prova2 {
width: 400px;
height: 200px;
-webkit-perspective: 400px;
perspective: 400px;
margin: 40px;
border: 1px solid #000;
overflow: hidden;
}
#rotate2 {
width: 200px;
height: 200px;
background-color: red;
-webkit-transform: rotateX(40deg);
transform: rotateX(40deg);
position: absolute;
bottom: 0px;
left: 100px;
}
答案 0 :(得分:0)
实际上溢出:隐藏隐藏透视区域。所以它不显示。
当你删除溢出:隐藏;它会正常工作
谢谢
答案 1 :(得分:0)
尝试直接在child中设置透视:
-webkit-transform: perspective(400px) rotateX(40deg) rotateY(0) translateZ(0);
结果是:
#prova2 {
position: relative;
width: 400px;
height: 200px;
margin: 40px;
border: 1px solid #000;
overflow: hidden;
border-radius: 30px;
}
#rotate2 {
width: 200px;
height: 200px;
background-color: red;
-webkit-transform: perspective(400px) rotateX(40deg) rotateY(0) translateZ(0);
position: absolute;
bottom: 0px;
left: 100px;
}