试一试
perspective: none;
perspective: 800px;
perspective: 23rem;
perspective: 5.5cm;
<section class="default-example" id="default-example">
<div class="transition-all" id="example-element">
<div class="face front">1</div>
<div class="face back">2</div>
<div class="face right">3</div>
<div class="face left">4</div>
<div class="face top">5</div>
<div class="face bottom">6</div>
</div>
</section>
#default-example {
background: linear-gradient(skyblue, khaki);
perspective: 800px;
perspective-origin: 150% 150%;
}
#example-element {
width: 100px;
height: 100px;
perspective: 550px;
transform-style: preserve-3d;
}
.face {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
position: absolute;
backface-visibility: inherit;
font-size: 60px;
color: white;
}
.front {
background: rgb(90 90 90 / 0.7);
transform: translateZ(50px);
}
.back {
background: rgb(0 210 0 / 0.7);
transform: rotateY(180deg) translateZ(50px);
}
.right {
background: rgb(210 0 0 / 0.7);
transform: rotateY(90deg) translateZ(50px);
}
.left {
background: rgb(0 0 210 / 0.7);
transform: rotateY(-90deg) translateZ(50px);
}
.top {
background: rgb(210 210 0 / 0.7);
transform: rotateX(90deg) translateZ(50px);
}
.bottom {
background: rgb(210 0 210 / 0.7);
transform: rotateX(-90deg) translateZ(50px);
}
语法
css
/* Keyword value */
perspective: none;
/* <length> values */
perspective: 20px;
perspective: 3.5em;
/* Global values */
perspective: inherit;
perspective: initial;
perspective: revert;
perspective: revert-layer;
perspective: unset;
值
描述
每个 z>0 的 3D 元素会变大;每个 z<0 的 3D 元素会变小。效果的强度由该属性的值决定。大的 perspective 值会导致小的变换;小的 perspective 值会导致大的变换。
位于用户后方的 3D 元素部分——即其 z 轴坐标大于 perspective CSS 属性的值的部分——不会被绘制。
消失点默认位于元素的中心,但其位置可以使用 perspective-origin 属性更改。
将此属性设置为除 none 以外的值会创建一个新的堆叠上下文。此外,在这种情况下,该对象将作为其包含的 position: fixed 元素的包含块。
正式定义
正式语法
perspective =
none |
<length [0,∞]>
示例
设置透视
在使用 CSS 变换 > 设置透视中给出了一个示例,展示了当 perspective 在不同位置设置时立方体的变化。
规范
| 规范 |
|---|
| CSS 变换模块级别 2 # perspective 属性 |
浏览器兼容性
加载中…