> 웹 프론트엔드 > CSS 튜토리얼 > CSS 호버 테두리가 인접한 요소를 이동하는 것을 어떻게 방지할 수 있습니까?

CSS 호버 테두리가 인접한 요소를 이동하는 것을 어떻게 방지할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-12-27 17:28:14
원래의
430명이 탐색했습니다.

How Can I Prevent CSS Hover Borders from Shifting Adjacent Elements?

CSS 호버 테두리로 요소 위치 조정

CSS 테두리로 호버 효과를 만들면 때때로 인접한 요소가 약간 이동하거나 "점프"할 수 있습니다. 이 문제는 테두리가 요소에 추가 너비를 추가하여 테두리가 없는 다른 요소에 비해 위치 지정이 변경될 때 발생합니다.

해결책: 투명 테두리

이 위치 지정을 해결하려면 문제가 발생하면 요소의 호버가 없는 상태에 투명한 테두리를 추가하세요. 이렇게 하면 마우스 오버 상태에 관계없이 모든 요소의 너비가 동일하여 예기치 않은 이동이 방지됩니다.

예: 수직 앵커 메뉴

내 앵커의 수직 메뉴를 고려하세요. 순서가 없는 목록. 다음 CSS 스니펫은 문제를 보여줍니다.

div a:visited, #homeheader a {
    text-decoration: none;
    color: black;
    margin-right: 5px;
}

div a:hover {
    background-color: #D0DDF2;
    border-radius: 5px;
    border: 1px solid #102447;
}

div li {
    padding: 0;
    margin: 0px 10px;
    display: inline;
    font-size: 1em;
}
로그인 후 복사

앵커 위로 마우스를 가져가면 추가된 테두리로 인해 왼쪽에 있는 모든 앵커가 오른쪽으로 약간 이동합니다.

이를 수정하려면, 마우스를 올리지 않은 상태에 투명한 테두리를 추가할 수 있습니다.

#homeheader a:visited, #homeheader a {
    border: 1px solid transparent;
}
로그인 후 복사

이 수정을 통해 모든 앵커의 너비가 일관되게 유지됩니다. "점프" 효과를 구현하고 적절한 요소 위치를 유지합니다.

위 내용은 CSS 호버 테두리가 인접한 요소를 이동하는 것을 어떻게 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿