> 웹 프론트엔드 > CSS 튜토리얼 > 다중 열 레이아웃에서 목록 항목이 여러 열로 나누어지는 것을 방지하는 방법은 무엇입니까?

다중 열 레이아웃에서 목록 항목이 여러 열로 나누어지는 것을 방지하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-12-16 11:28:11
원래의
297명이 탐색했습니다.

How to Prevent List Items from Breaking Across Columns in Multi-Column Layouts?

요소 내에서 열 나누기 방지

다중 열 레이아웃에서는 개별 목록 항목이 여러 열로 나누어지는 경우가 발생할 수 있습니다. 이러한 원치 않는 동작을 방지하려면 break-inside CSS 속성을 사용할 수 있습니다.

break-inside 사용

구체적으로 목록 항목 요소에 break-inside: escape-column을 설정하면 다음이 보장됩니다. 단일 열 내에서 그대로 유지됩니다:

.x li {
    break-inside: avoid-column;
}
로그인 후 복사

Firefox 호환성 문제

안타깝게도 2021년 10월 현재 Firefox는 break-inside 속성을 지원하지 않습니다. 다른 주요 브라우저에서 사용할 수 있지만 Firefox에 대한 해결 방법이 필요합니다.

Firefox에 대한 해결 방법

Firefox에 대한 덜 바람직한 해결 방법은 깨지지 않는 콘텐츠를 테이블에 래핑하는 것입니다.

<div class='x'>
    <table>
        <tr><td>Number one</td></tr>
        <tr><td>Number two (longer)</td></tr>
        <tr><td>Number three</td></tr>
    </table>
</div>
로그인 후 복사

Firefox 20 지원(일부)

Firefox 20에서는 다음에 대한 지원을 도입했습니다. page-break-inside: 방지하지만 목록 문제를 완전히 해결하지는 않습니다. 다음 코드는 항목이 여전히 중단됨을 보여줍니다.

.x {
    column-count: 3;
    width: 30em;
}

.x ul {
    margin: 0;
}

.x li {
    -webkit-column-break-inside: avoid;
    -moz-column-break-inside:avoid;
    -moz-page-break-inside:avoid;
    page-break-inside: avoid;
    break-inside: avoid-column;
}
로그인 후 복사
<div class='x'>
    <ul>
        <li>Number one, one, one, one, one</li>
        <li>Number two, two, two, two, two, two, two, two, two, two, two, two</li>
        <li>Number three</li>
    </ul>
</div>
로그인 후 복사

위 내용은 다중 열 레이아웃에서 목록 항목이 여러 열로 나누어지는 것을 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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