a

날나리 강좌. ㅋ HTML DTD

앞서 SGML에 관해서 간단히 이야기 했습니다. SGML은 메타적인 언어로 사실상 어떠한 마크업으로 작성하겠다는 선언적 의미를 가질 뿐이며 이것의 구현은 어디까지나 해당 문서를 제안하고 이러한 내용으로 쓰겠다는 사람들의 몫입니다. 구체적으로 HTML 문서형식까지 내려오면서 이에 맞게 특화된 브라우저가 바로 웹브라우저이고요. 

여기서 SGML은 SGML Declaration, SGML DTD, SGML Document Instance로 나눠볼 수 있다고 하였습니다. 우리가 웹 HTML 문서를 작성하는 것은 SGML Document Instance입니다. 마크업에 관련된 내용인 SGML Declaration과 요소 사용에 관한 규칙을 다룬 SGML DTD는 이미 W3C란 곳을 통해서 정해졌고 그곳에서 나온 권고안을 따릅니다. 

HTML이 SGML을 처음부터 염두하고 만들었는지에 관한 이야기는 분분합니다. 그러나 SGML도 표준화법용마크업이라는 단어적인 의미를 그대로 본다면 기존의 HTML이 SGML에 관해 포함시키거나 하는 것도 그리 어려운 내용은 아니었을 것입니다. 적어도 HTML DTD는 HTML2.0쯔음에 등장하였고 이떄부터 SGML로 보기에는 맞긴 합니다. 

2000년대 초에 나온 애니매이션 공각기동대를 보면은 몇회인지 모르겠지만 중간에 소스코드가 나오는데 이때 HTML DTD가 나오더라고요. 

그렇다면 HTML DTD는 어떠한 의미를 가지고 있을까요? 일단은 이것을 정하고 발행하는 곳은 W3C입니다. 과거에는 브라우저 전쟁이라고 해서 넷스케이프 진영과 익스플로어와의 시장에서 큰 싸움이 있었고 결국 익스의 승리로 끝나는 것 같았으나 다시 2차(?) 전쟁이 시장에서 벌어졌죠. 파이어폭스 등장이나 꾸준한 사랑을 받는 오페라, 그리고 각종 모바일 기기 부터 TV까지 다양한 플래폼으로 나오게 되었습니다. 

과거 1차 전쟁때는 HTML 문서에 관해 이렇다할 약속보다는 각 브라우저 회사마다 자기만의 독특한 내용이 많았습니다. IE의 Marquee 태그나 넷스케이브사의 Blink 같은 태그죠. 이것들은 양측의 합의를 걸쳐 둘다 결국 사라졌지만, Marquee는 아마 여전히 익스에서 동작할 것이고요. 

여튼 이러한 혼란속에 또한 합의와 함께 HTML DTD의 적시는 W3C에서 제안한 것을 따른다는 의미를 갖게되었고, 이것이 문서 쓰기에 웹표준의 시작점이 되었을 것입니다. 

사실 HTML DTD는 그저 요소간의 부모관계나 속성 및 값에 관한 내용을 담은 Schema인데, 이것은 이제 그 이상의 의미를 가져 심지어 CSS 처리나 DOM 관련 내용까지 작동되는 방식에 관여하게 되었습니다.

W3C에서 제안한 HTML 문서 형식은 다양한 버전이 존재합니다. 많이 쓰이던 과거의 4.01부터 이를 XML 문법에 맞처 만든 XHTML 1.1, 또한 각각의 버전에서 보다 엄격히 따르겠다는 Strict, 가령 deprecated 된 요소까지 다루는 transitional, 또한 프레임에 관한 내용을 다룬 것까지 종류가.... 과연 무엇을 써야 하는 것이 옳을까요? 그것은 작성하는 사람의 목적에 달려있습니다라고 말하면 너무 허무한 결론이며 저는 다음과 같이 사용합니다.

<!doctype html>

보통 HTML5의 DTD라고 이야기하나 사실 DTD를 받으면 브라우저가 이에 맞춰 처리해야하는데 실상은 그러하지 못합니다. 파이어폭스가 엄격히 따져 DTD를 가려 처리하기는 하지만 IE는 별차이 없기도 합니다. 다만 구형 IE 브라우저를 포함하여 또한 HTML5까지 담아볼 수 있는 DTD가 위와 같이 간단한 것이 아닐까 합니다.  또한 외워서 적기에는 참 깁니다. ㅎㅎ 그저 위와같이 짧게 적으면 그것이면 일단 원하는 것에 족합니다. Ie6도 비록 html5가 몬지 모르지만 이것을 보면 이 문서는w3c 동네의 dtd로, 곧 웹표준(?) 문서이구나 하면서 그렇게 처리합니다.  
|

댓글 1개

긴글 잘봤습니다 수고 하셨습니다
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 3,343
14년 전 조회 1,264
14년 전 조회 691
14년 전 조회 763
14년 전 조회 750
14년 전 조회 848
14년 전 조회 619
14년 전 조회 691
14년 전 조회 1,342
14년 전 조회 3,205
14년 전 조회 1,617
14년 전 조회 727
14년 전 조회 671
14년 전 조회 797
14년 전 조회 667
14년 전 조회 764
14년 전 조회 877
14년 전 조회 676
14년 전 조회 3,171
14년 전 조회 3,083
14년 전 조회 875
14년 전 조회 1,387
14년 전 조회 1,003
14년 전 조회 862
14년 전 조회 3,406
14년 전 조회 2,402
14년 전 조회 2,001
14년 전 조회 1,914
14년 전 조회 695
14년 전 조회 1,450
14년 전 조회 697
14년 전 조회 597
14년 전 조회 633
14년 전 조회 1,053
14년 전 조회 1,084
14년 전 조회 1,666
14년 전 조회 831
14년 전 조회 1,046
14년 전 조회 1,211
14년 전 조회 1,214
14년 전 조회 557
14년 전 조회 1,737
14년 전 조회 914
14년 전 조회 1,215
14년 전 조회 992
14년 전 조회 1,321
14년 전 조회 1,428
14년 전 조회 859
14년 전 조회 1,078
14년 전 조회 1,361
14년 전 조회 1,424
14년 전 조회 802
14년 전 조회 950
14년 전 조회 1,663
14년 전 조회 2,764
14년 전 조회 2,017
14년 전 조회 2,080
14년 전 조회 1,478
14년 전 조회 1,293
14년 전 조회 1,184
14년 전 조회 972
14년 전 조회 437
14년 전 조회 1,350
14년 전 조회 4,458
14년 전 조회 1,327
14년 전 조회 1,097
14년 전 조회 592
14년 전 조회 819
14년 전 조회 635
14년 전 조회 526
14년 전 조회 601
14년 전 조회 586
14년 전 조회 523
14년 전 조회 1,401
14년 전 조회 728
14년 전 조회 582
14년 전 조회 553
14년 전 조회 605
14년 전 조회 903
14년 전 조회 805
14년 전 조회 1,400
14년 전 조회 1,022
14년 전 조회 3,472
14년 전 조회 700
14년 전 조회 1,256
14년 전 조회 984
14년 전 조회 2,727
14년 전 조회 2,329
14년 전 조회 536
14년 전 조회 1,594
14년 전 조회 540
14년 전 조회 2,344
14년 전 조회 1,891
14년 전 조회 501
14년 전 조회 5,588
14년 전 조회 851
14년 전 조회 1,359
14년 전 조회 1,179
14년 전 조회 1,218
14년 전 조회 1,102
🐛 버그신고