CSS로 다른 요소의 상태에 따라 요소를 선택하는 방법
소개
특정 요소를 타겟팅하는 것은 항상 CSS의 기본 측면이었습니다. 그러나 페이지의 다른 요소 상태에 따라 요소의 스타일을 지정해야 할 경우 복잡성이 발생합니다. 이 문서에서는 현재 CSS 선택기의 제한 사항을 살펴보고 향후 표준의 잠재적인 솔루션을 소개합니다.
현재 CSS 선택기의 제한 사항
CSS 선택기에는 요소 선택에 몇 가지 제한 사항이 있습니다. 다른 사람의 상태를 기준으로 합니다. 첫째, 상위 선택자나 이전 형제 선택자를 사용하여 요소의 상태에 직접 액세스할 수 없습니다. 둘째, 선택기의 주제로 단일 요소만 타겟팅할 수 있으므로 조건에 따라 여러 요소에 스타일을 적용할 수 없습니다.
예: 호버 상태를 기반으로 요소 타겟팅
한 페이지에 여러 섹션이 있다고 가정해 보겠습니다. 각 섹션에는 해당 상태를 나타내는 "완료" 데이터 속성이 있는 div가 포함되어 있습니다. "finished" 속성이 있는 div를 마우스로 가리킬 때마다 다음 섹션에서 깜박이고 회전하는 요소에 색상 테두리를 추가하려고 합니다. 이에 대한 간단한 CSS 선택기는 다음과 같습니다.
section:hover + section .blink, section:hover + section .spin { border: 1px solid red; }
그러나 CSS에는 첫 번째 섹션의 div를 대상으로 하는 상위 선택기가 없기 때문에 작동하지 않습니다.
잠재적인 해결책: Selectors 4 및 :has()
다가오는 Selectors 4 초안에서는 이 문제를 해결하는 :has()라는 의사 클래스입니다. :has()를 사용하면 특정 자손이 있는 요소를 선택할 수 있습니다. 사용된 요소의 하위 항목과 일치하는 상대 선택기 인수를 사용합니다.
위 문제에 대해 :has()를 사용하는 솔루션은 다음과 같습니다.
section:has(div[data-status~=finished]) + section div:matches(.blink, .spin) { border: 1px solid red; }
여기서: has()는 선택기가 "완료" 상태의 div가 포함된 섹션만 대상으로 지정하도록 합니다. 또한 하위 조합자를 :matches()와 결합하여 후속 섹션에서 깜박이는 요소와 회전하는 요소를 모두 대상으로 삼습니다.
결론
현재 CSS 선택기는 선택에 제한이 있습니다. 다른 요소의 상태를 기반으로 하는 요소의 경우 Selectors 4의 곧 출시될 :has() 의사 클래스가 잠재적인 솔루션을 제공합니다. 선택기 구문이 향상되어 더 많은 유연성과 요소의 조건부 타겟팅이 가능해졌습니다.
위 내용은 CSS 선택기가 다른 요소의 상태에 따라 요소를 대상으로 지정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

CSS 그리드는 복잡하고 반응이 좋은 웹 레이아웃을 만드는 강력한 도구입니다. 디자인을 단순화하고 접근성을 향상 시키며 이전 방법보다 더 많은 제어를 제공합니다.

기사는 반응 형 설계에서 공간의 효율적인 정렬 및 분포를위한 레이아웃 방법 인 CSS Flexbox에 대해 설명합니다. Flexbox 사용을 설명하고 CSS 그리드와 비교하고 브라우저 지원 세부 사항을 설명합니다.

이 기사는 Viewport Meta 태그, 유연한 그리드, 유체 미디어, 미디어 쿼리 및 상대 장치를 포함하여 CSS를 사용하여 반응 형 웹 사이트를 만드는 기술에 대해 설명합니다. 또한 CSS 그리드 및 Flexbox를 함께 사용하여 CSS 프레임 워크를 권장합니다.

이 기사는 요소 치수 계산 방법을 제어하는 CSS 박스 크기 속성에 대해 설명합니다. Content-Box, Border-Box 및 Padding-Box와 같은 값과 레이아웃 설계 및 형태 정렬에 미치는 영향을 설명합니다.

기사는 CSS, 주요 특성 및 JavaScript와 결합 된 애니메이션 작성에 대해 논의합니다. 주요 문제는 브라우저 호환성입니다.

기사는 3D 변환, 주요 속성, 브라우저 호환성 및 웹 프로젝트에 대한 성능 고려 사항에 대한 CSS 사용에 대해 논의합니다. (문자 수 : 159)

이 기사는 CSS 그라디언트 (선형, 방사형, 반복)를 사용하여 웹 사이트 비주얼을 향상시키고 깊이, 초점 및 현대적인 미학을 추가합니다.

기사는 CSS의 의사 요소, HTML 스타일을 향상시키는 데 사용 및 의사 급의 차이점에 대해 설명합니다. 실제 사례를 제공합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.