소개
그것은 일반적으로 인라인 요소 내에 블록 요소를 배치하는 것은 올바르지 않다고 이해됩니다. 그러나 그 반대가 발생하면 어떻게 될까요? 구체적으로, 단락이 포함된 div가 CSS에 의해 인라인으로 변환된 경우에도 HTML 유효성 검사 규칙을 준수합니까?
CSS 사양
CSS 2.1 사양에 따르면 , 블록 수준 상자를 포함하는 인라인 상자는 블록 수준 상자 앞과 뒤의 두 개의 익명 블록 상자로 분할됩니다. 이 상자는 블록 수준 상자의 형제가 됩니다. 이 동작은 익명 블록 상자가 비어 있는 경우에도 적용됩니다.
HTML 유효성 검사
HTML 유효성 검사 상태는 CSS 적용 이전 또는 이후에 평가되는지에 따라 달라집니다. CSS가 적용되기 전에는 HTML이 유효합니다. 그러나 CSS 변환 후에는 HTML 사양에 따라 문서가 더 이상 유효하지 않을 수 있습니다.
구현 및 브라우저 지원
CSS 사양은 브라우저가 어떻게 해야 하는지에 대한 지침을 제공합니다. 이 시나리오를 처리하세요. 그러나 브라우저 구현은 다를 수 있습니다. 일부 브라우저는 중첩된 블록 주위에 "익명 라인 상자"를 생성하여 블록을 포함하는 인라인 요소에 테두리를 구현했습니다. 이 동작은 CSS1 또는 CSS2에 명시적으로 정의되어 있지 않으며 모든 브라우저에서 일관되지 않을 수 있습니다.
HTML5 고려 사항
HTML5에서는 블록 수준 배치가 허용됩니다. 링크와 같은 인라인 요소 내부의 요소. 이는 클릭 가능한 HTML 콘텐츠의 큰 블록을 생성할 때 유용할 수 있습니다.
결론
CSS 변환 후 인라인 요소 내에 포함된 블록 요소의 동작은 CSS에 지정되어 있습니다. 사양에 따라 이 규칙의 해석 및 구현은 브라우저마다 다를 수 있습니다. HTML 유효성 검사에 미치는 영향은 CSS 적용 전후, 유효성 검사가 수행되는 시점에 따라 달라집니다.
위 내용은 다른 블록 요소가 포함된 경우 CSS를 통해 블록 요소를 인라인으로 변환하는 것이 유효한 HTML입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!