태그에는
같은 블록 태그를 넣을 수 □다!

다들 HTML 배우면서 가장 간단하면서 많이 지키는 사항이 있다. 물론 맞는 말이다. 표준이기 때문에.

  • inline 요소 안에는 block 요소를 자식으로 가질 수 없다.
  • block 요소 안에는 inline 및 block 요소가 모두 허용된다.
  • 단, p 요소 안에는 inline 요소만 허용된다.
  • inline 요소 안에는 inline 요소만 허용된다.

근데 나모 웹에디터 때문에 <p> 요소에다가 <div> 넣는 등의 표준을 위반하는 사례가 있다. 그리고 IE 기반 위지윅 에디터가 그리한데, designMode 기능이 기본 문단 태그를 <p> 로 지정했기 때문이다. 그래서 초창기 위지윅 에디터가 상당히 말이 많았고, 그리고 이에 대한 문제를 고치느라 고생하던 시절이 있었다.

하지만 지금은 많은 위지윅 에디터가 문단 태그를 <div> 로 강제하였기 때문에 더이상 HTML 표준 위반 및 XHTML 표준 전선 이상 무!

자. 잡담은 끝내고 이제 본론으로 들어가보자. HTML 표준에는 일단 문장(inline) 요소에는 문단(block) 요소를 넣을 수 없게 되어 있다. 따라서 원래 <a> 태그에 <div> 태그같은 게 들어갈 수 없는게 정설이다.

하지만 HTML5 부터는 얘기가 달라졌다.

마치 p 태그가 인라인 요소만 허용한다는 예외 처럼, a 태그에도 예외가 생겼다.



두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구



그러하다.
HTML5 에서는 <a> 태그 안에 아무 태그나 넣을 수 있게 되었다.
이 때문에, 플랫 디자인 다음이 뜬금없는 카드 디자인 패턴이 나온 것이다.
예제 코드를 보자.
<article>
<a href="story1.html">
<h3>Bruce Lawson voted sexiest man on Earth</h3>
<p><img src="bruce.jpg" alt="gorgeous lovebundle. ">A congress representing all the planet's women unanimously voted Bruce Lawson as sexiest man alive.</p>
<p>Read more</p>
</a>
</article>
이렇게 생겼다.
하나의 글 영역 안에 모든 것들을 링크 걸고, 그 안에 제목과 요약 내용, 그리고 read more 라고 링크를 부추기는 글을 넣는다.
이렇게 하면 장점이 뭐냐?
웹 접근성이 향상된다. 모바일이나 특수 컴퓨터 (시력장애인 등을 위한) 에서 링크 클릭에 대한 접근성이 향상된다.
또한 이런 접근성으로 인해 스크립트 의존성이 떨어지며, 원하는 문서를 손쉽게 이동할 수 있는 장점이 생긴다.
바로 접근성을 고려해서 W3C가 이렇게 HTML5 표준과 함께 내놓은 거다.
여담으로, XHTML2 에서는 모든 요소에 href 를 넣을 것을 고려했다고 한다. 바로 이런 접근성에 용이하기 위해.
하지만 알다시피 XHTML2 는 완전히 새로운 표준을 지향했고, 하위 호환성이 철저히 무시한 덕분에 많은 웹 관련 개발자와 디자이너, 연구진들이 반발했고, 그리고 무산된 표준이 바로 XHTML2 였다.
만약 XHTML2 표준으로 웹 페이지를 만들었고, 브라우저가 그걸 지원하려면 정말 엄청 머리 아팠을 것 같지 않은가?
왜냐하면 바로 하위 호환성이 사라지기 때문에, 엔진을 2개 만들어야 하는 꼴이 되니까. 당연히 달갑지 않았던 거다.
지금은 HTML5 에서는 이 표준이 아직 하위 호환성이 적잖아 문제가 있다. 모든 브라우저가 이 표준을 지원한다. 쿼크 모드에 대한 호환성 때문인데, 이 기능이 지원된 게 다행이라 생각하지 않는가? 만약 <div> 가 <a> 로 감쌌다고 지우면, 이건 정말 골치아플 수도 있다.
하지만 아직까지 현재 브라우저에 한계가 있는데,
비록 <a> 태그 안에 모든 태그가 지원된다 해도, 현재 표준에 의한 예외 사항이 있는데, 바로 테이블이다.
테이블 태그 안에 비표준 태그들을 싸그리 지우도록 엔진이 설계한 덕분에, <a> 태그를 <tr> 안에 넣지 못하는 사태가 일어난다.
이에 대응할 지는 아직 지켜봐야 할 단계지만, 이를 지원한다면, 웹 접근성 향상에 어느정도 기여할 것으로 기대된다.
자. 이제 찬양하라. HTML5를!
자세한 링크는 HTML5 에서 신뢰성 있는 정보를 제공하는 HTML5닥터 에서 보도록 한다.

composite / 2014년 2월 18일 / 미분류
태그:, , , , , , , ,

답글 남기기

Your email address will not be published / Required fields are marked *