>웹 프론트엔드 >CSS 튜토리얼 >CSS `transform`의 `perspective()` 순서가 3D 변환에 중요한 이유는 무엇입니까?

CSS `transform`의 `perspective()` 순서가 3D 변환에 중요한 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-01 03:51:09817검색

Why Does the Order of `perspective()` in CSS `transform` Matter for 3D Transformations?

CSS 3D 변환: 관점 상호 작용

CSS에서 3D 변환을 적용할 때 실행 순서가 중요한 역할을 합니다. 이는spective() 함수를 사용할 때 특히 관련이 있습니다.

문제 설명

사용자는 변환 속성이spective() 함수를 사용하는지 여부에 따라 다른 효과를 나타내는 것을 관찰했습니다. 함수는 속성 값의 시작 또는 끝 부분에 선언됩니다. 이 동작은 Chrome 및 Firefox 브라우저 모두에서 목격되었습니다.

근본 원인

CSS 사양에 따르면 변환 행렬은 왼쪽부터 변환 함수를 적용하여 계산됩니다. 오른쪽으로. Perspective() 함수가 마지막에 배치되면 번역과 같은 다른 모든 변환 후에 적용됩니다. 이로 인해 원근을 고려하지 않고 번역이 수행됩니다.

해결책

정확한 3D 변환을 보장하려면 관점() 함수를 다음 단계에 지정하는 것이 필수적입니다. 변환 속성의 시작 value.

예:

box:nth-child(1):hover {
  transform: perspective(1000px) translate3d(0, 0, -100px);
}

box:nth-child(2):hover {
  transform: translate3d(0, 0, 100px) perspective(1000px);
}

이 예에서 첫 번째 상자는 원근 효과가 적용된 3D 공간에서 변환되지만 두 번째 상자는 변환되지 않습니다. 관점을 적용하세요.

추가 고려 사항:

  • 변환 중인 요소 내에서는 관점 속성을 사용하지 않는 것이 좋습니다. 예상치 못한 결과가 발생할 수 있습니다.
  • 변형 함수의 순서는 중요하며 결과에 영향을 미칠 수 있습니다. 다양한 시퀀스의 영향을 실험하고 탐색하는 것이 중요합니다.

위 내용은 CSS `transform`의 `perspective()` 순서가 3D 변환에 중요한 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.