perspective

Baseline 已廣泛支援

此特性已相當成熟,可在許多裝置和瀏覽器版本上使用。自 2015 年 9 月以來,該特性已在各大瀏覽器中可用。

perspective CSS 屬性決定了 z=0 平面與使用者之間的距離,以便為 3D 定位元素提供一些透視效果。

試一試

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;

none

表示不應用透視變換。

<length>

一個 <length> 值,表示使用者到 z=0 平面的距離。它用於對其子元素應用透視變換。負值是語法錯誤。如果值小於 1px,則會被限制為 1px

描述

每個 z>0 的 3D 元素會變大;每個 z<0 的 3D 元素會變小。效果的強度由該屬性的值決定。大的 perspective 值會導致小的變換;小的 perspective 值會導致大的變換。

位於使用者後方的 3D 元素部分——即其 z 軸座標大於 perspective CSS 屬性的值的部分——不會被繪製。

消失點預設位於元素的中心,但其位置可以使用 perspective-origin 屬性更改。

將此屬性設定為除 none 以外的值會建立一個新的堆疊上下文。此外,在這種情況下,該物件將作為其包含的 position: fixed 元素的包含塊。

正式定義

初始值none
應用於可變換元素
繼承性
計算值絕對長度或 none
動畫型別一個長度
建立層疊上下文

正式語法

perspective = 
none |
<length [0,∞]>

示例

設定透視

使用 CSS 變換 > 設定透視中給出了一個示例,展示了當 perspective 在不同位置設定時立方體的變化。

規範

規範
CSS 變換模組級別 2
# perspective 屬性

瀏覽器相容性

另見