그라데이션 배경의 투명 테두리 왜곡
CSS에서 선형 그라데이션 배경의 요소에 투명한 테두리를 적용하면 비정상적인 오류가 발생할 수 있습니다. 요소의 왼쪽 및 오른쪽 가장자리가 왜곡되거나 편평해진 색상을 나타내는 효과입니다.
이는 다음과 같은 이유로 발생합니다. 그래디언트의 시작점과 끝점은 패딩 상자의 가장자리에 있고 테두리는 패딩 상자 외부에 렌더링됩니다. 결과적으로 패딩박스 양쪽에 배경이 반복되어 보더박스를 채우게 되면서 시각적으로 테두리가 일그러진 것처럼 보입니다.
왜곡의 원인
이러한 왜곡의 이유는 브라우저가 CSS 상자 모델을 해석하는 방식에 있습니다. padding-box는 요소의 콘텐츠가 배치되는 영역을 결정하는 반면, border-box는 padding-box와 테두리를 둘러쌉니다. 주어진 시나리오에서 그라데이션 배경은 패딩 상자 내에 포함되어 있지만 투명한 테두리는 경계를 넘어 확장됩니다.
해결 방법
이 문제를 해결하려면 다음 중 하나를 수행하세요. "box-shadow: inset"이라는 CSS 속성을 사용할 수 있습니다. 테두리와 달리 삽입 상자 그림자는 패딩 상자 내에 렌더링되어 왜곡을 일으키지 않고 테두리와 시각적으로 유사한 효과를 제공합니다.
테두리를 다음 상자 그림자 속성으로 대체하면 원하는 모양이
box-shadow: inset 0 0 0 10px rgba(0,0,0,0.2);
게다가 박스 섀도우는 테두리처럼 공간을 차지하지 않기 때문에 패딩을 늘려야 합니다.
그림
다음 다이어그램은 패딩 상자와 테두리 상자의 차이점을 보여줍니다.
[패딩 상자 이미지 및 border-box]
데모
솔루션의 대화형 데모는 다음에서 찾을 수 있습니다: http://jsfiddle.net/ilpo/fzndodgx/5/
위 내용은 투명 테두리가 CSS의 그라데이션 배경을 왜곡하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!