이번에는 실제 전투에서 CSS를 사용하는 기술을 공유하겠습니다. 실제 전투에서 CSS를 사용할 때 주의사항은 무엇인가요?
클리핑 애니메이션의 경우 너비/높이 대신 클립 경로를 사용하여 DOM 재배열로 인해 성능이 저하되는 것을 방지하세요.
.animate { width: 200px; height: 200px; background: #000; animation: 1s clip; } @keyframes clip { 0% { clip-path: inset(0 0 0 0); } 100% { clip-path: inset(0 100% 100% 0); } }
clip-path는 다른 일반/불규칙한 그래픽을 잘라내는 데도 사용할 수 있습니다.
.clip { clip-path: polygon(0 100%, 50% 0, 100% 100%, 0 30%, 100% 30%); /* 多边形 */ clip-path: circle(30px at 35px 35px); /* 圆形 */ clip-path: ellipse(30px 25px at 35px 35px); /* 椭圆 */ }
transform3d를 사용하여 GPU 가속을 활성화하는 것 외에도 will-change를 사용하여 GPU 가속을 강제하여 애니메이션 성능을 최적화할 수도 있습니다.
.animate { width: 200px; height: 200px; background: #000; animation: 1s clip; will-change: clip-path; } @keyframes clip { 0% { clip-path: inset(0 0 0 0); } 100% { clip-path: inset(0 100% 100% 0); } }
패딩 시뮬레이션을 사용한 다음 하위 요소의 절대 위치 지정
/* 1:1 */ .container { width: 200px; } .container:after { display: block; content: ' '; padding-top: 100%; } /* 16:9 */ .container { width: 200px; } .container:after { display: block; content: ' '; padding-top: calc(100% * 9 / 16); }
일반적으로 사용되는 방법:
dislay: inline-block
상단: 50% + 변환: tranlsateY(-50%)
display: flex
기타에는 위 및 아래 패딩 지원
, display: table
, <a href="http://www.php.cn/wiki/902.html" target="_blank">position<code>padding上下撑高
、display: table
、<a href="http://www.php.cn/wiki/902.html" target="_blank">position</a> + margin: auto
、绝对定位 + margin
等等,这些属于不常用、特殊场景才能用、CSS3之前的hack方式,CSS3之后就不必使用这些来实现垂直居中,就不多说了。
其中display: flex
+ 여백: 자동, 절대 위치 지정 + 여백
code> 등은 일반적으로 사용되지 않고 특수한 시나리오에서만 사용할 수 있으며 CSS3 이전의 해킹 방법입니다. CSS3 이후에는 수직 센터링을 달성하기 위해 이것을 사용할 필요가 없으므로 사용하지 않겠습니다. 자세히 살펴보세요.
display: flex
는 뱀기름입니다. 대부분의 시나리오에서 직접 사용할 수 있지만 사용할 수 없는 특별한 경우도 있습니다. 이 기사의 사례를 읽으신 후 마스터하셨다고 믿습니다. 더 흥미로운 방법을 알고 싶다면 PHP 중국어 웹사이트의 다른 관련 기사를 주목해 보세요!
프런트 엔드 프로젝트에서 프로젝트 구조 초기화js 변수 범위를 사용할 때 발생하는 버그🎜🎜위 내용은 실제 전투에서 CSS를 사용하는 팁 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!