본문으로 이동

HTML

위키백과, 우리 모두의 백과사전.

HTML
(HyperText Markup Language)
개발자W3CWHATWG
발표일1993년(31년 전)(1993)
최근 버전Living Standard
최근 버전 출시일2022년
웹사이트http://www.w3.org/
주요 구현체
TEXT/HTML
영향을 받은 언어
SGML
영향을 준 언어
XHTML

하이퍼 텍스트 마크업 언어(영어: Hyper Text Markup Language, HTML, 문화어: 초본문표식달기언어, 하이퍼본문표식달기언어)는 웹 페이지 표시를 위해 개발된 지배적인 마크업 언어다. 또한, HTML은 제목, 단락, 목록 등과 같은 본문을 위한 구조적 의미를 나타내는 것뿐만 아니라 링크, 인용과 그 밖의 항목으로 구조적 문서를 만들 수 있는 방법을 제공한다. 그리고 이미지와 객체를 내장하여 대화형 양식을 생성하는 데 사용될 수 있다. HTML은 웹 페이지 콘텐츠 안의 꺾쇠 괄호에 둘러싸인 "태그"로 되어있는 HTML 요소 형태로 작성한다. HTML은 웹 브라우저와 같은 HTML 처리 장치의 행동에 영향을 주는 자바스크립트, 본문과 그 밖의 항목의 외관과 배치를 정의하는 CSS 같은 스크립트를 포함하거나 불러올 수 있다. HTML과 CSS 표준의 공동 책임자인 W3C는 명확하고 표상적인 마크업을 위하여 CSS의 사용을 권장한다.[1]

역사

[편집]

개발

[편집]
팀 버너스리

1980년, 유럽 입자 물리 연구소(CERN)의 계약자였었던 물리학자 팀 버너스리가 HTML의 원형인 인콰이어를 제안하였다. 인콰이어는 CERN의 연구원들이 문서를 이용하고 공유하기 위한 체계였다. 1989년에 팀 버너스리는 인터넷 기반 하이퍼텍스트 체계를 제안하는 메모를 작성했다.[2] 버너스 리는 1990년 말에 HTML을 명시하고, 브라우저와 서버 소프트웨어를 작성했다. 그 해에 버너스리와 CERN 데이터 시스템 엔지니어 로버트 카일리아우와 함께 CERN측에 자금 지원을 요청하였지만, 이 프로젝트는 CERN으로부터 정식으로 채택 받지 못했다. 버너스리의 개인적인 기록[3]에 1990년부터 "하이퍼텍스트가 사용되는 여러 분야의 일부"를 열거했고 백과사전을 그 목록의 첫 번째로 두었다.

최초 규격

[편집]

HTML 최초의 일반 공개 설명은 1991년 말에 버너스리가 처음으로 인터넷에서 문서를 "HTML 태그"(HTML tag)로 부르면서 시작되었다.[4][5]

그것은 머릿글자로 이루어진 20개의 요소를 기술하였고, 상대적으로 HTML의 단순한 디자인이었다. 하이퍼링크를 제외한 HTML 태그들은 CERN 자체의 SGML 기반 문서화 포맷인 SGML GUID에 강하게 영향을 받았다. 이 요소 중 13개는 HTML 4 버전에서도 여전히 존재한다.[6]

HTML은 동적인 웹 페이지의 웹 브라우저를 통한 문자와 이미지 양식이다. 문자 요소의 대부분은 1988년 ISO 기술 보고서 9537 SGML을 이용한 기법에서 찾을 수 있다. 하지만 SGML 개념의 일반적인 마크업은 단지 개별 효과 보다는 요소 기반이고 또한 구조와 처리의 분리(?)(HTML은 CSS와 함께 이 방향으로 점진적으로 이동해 왔다.)

버너스리는 SGML 응용 프로그램이 되는 HTML을 고안해야 했고 그것은 공식적으로 IETF(국제 인터넷 표준화 기구)에 의하여 1993년 중반, HTML 규격에 대한 최초의 제안을 간행물로 정의했다. (버너스리와 덴 콘놀리에 의한 문법을 규정하는 SGML 문서 형식 정의(SGML DTD)가 포함된 "하이퍼텍스트 마크업 언어(HTML)" 인터넷 초안[7]) 이 초안은 6개월 후 만료된다. 하지만 NCSA 모자이크 브라우저의 인라인 이미지를 내장하는 사용자 정의 태그의 사례는 주목할 만 했고, 성공적인 프로토타입에 대한 표준을 기반한 IETF의 철학을. [8] 마찬가지로 데이브 라그렛의 경쟁 인터넷 초안인 "HTML+ (하이퍼텍스트 마크업 포맷)"은 1993년 말에 테이블과 기입양식 같은 요소들을 이미 구현하여 표준화 제안을 했다.[9]

이후 1994년 초 HTML과 HTML+ 초안은 만료되었고, IETF는 HTML 작업 그룹을 설립해 1995년에 HTML 2.0을 완성한다. 최초의 HTML의 규격은 미래에 수행될 HTML 표준을 기반으로 간주되는 경향이 있었다.[8]RFC 1996년에 HTML 2.0은 HTML과 HTML+ 초안의 아이디어가 포함됐다고 발표했다.[10] HTML 2.0 지정은 이전의 초안들로부터 새로운 버전을 구별하기 위해서였다.[11]

게다가 IETF의 후원하에 개발은 상충하는 이해 관계 때문에 지연되었다. 1996년부터 HTML 규격은 상용 소프트웨어 제작사의 투입으로 월드 와이드 웹 컨소시엄(W3C)에서 유지해 왔다.[12] 하지만 2000년부터 HTML 또한 국제 표준(ISO/IEC 15445:2000)이 되었다. 현재 W3C에 의해 발표된 최신 규격은 1999년 말에 발표된 HTML 4.01 권고안이며 2001년에 문제와 오류들이 수정되어 발표된 안이 최종 승인되었다.

표준 버전의 역사

[편집]

HTML 버전 스케줄

[편집]
1995년 11월 24일
HTML 2.0이 IETFRFC 1866로 발표되었다. 추보의 RFC의 추가된 기능:
  • 1995년 11월 25일: RFC 1867 (양식 기반 파일 업로드)
  • 1996년 5월: RFC 1942 (테이블)
  • 1996년 8월: RFC 1980 (클라이언트 측 이미지맵)
  • 1997년 1월: RFC 2070 (국제화)
2000년 6월, 이 모든 것들이 RFC 2854에 의하여 더 이상 쓰이지 않고 역사적인 것으로 선언됨.
1997년 1월
HTML 3.2[13] 가 W3C 권고안으로 발표되었다. 이것은 1996년 9월에 폐쇄한 HTML 작업 그룹인 IETF와 같이 W3C에 의하여 배타적으로 개발되고 표준화된 첫 번째 버전이다.[14]
HTML 3.2에서 여러 종류의 겹치는 확장 수학 수식을 완전히 제외 시키고 넷스케이프의 비주얼 마크업 태그의 대다수를 채택했다. 넷스케이프의 블링크 요소와 마이크로소프트의 마퀴 요소는 두 회사의 상호 협의 하에 누락시켰다.[12] HTML에서 수학적 수식과 비슷한 마크업은 이후 MathML이 나올 때까지 14개월 동안 표준이 아니었다.
1997년 12월
HTML 4.0[15]

이 W3C 권고안으로 출시되었다. HTML 4.0은 세 가지 문서 형태를 제공한다:

  • Strict(엄격): 사용이 중지된 요소를 금지한다.
  • Transitional(변이): 사용이 중지된 요소를 허용한다.
  • Frameset(프레임셋): 대부분 프레임 관련 요소에서만 허용한다.
처음에 코드네임 "쿠가"[16]에서 HTML 4.0은 다양한 브라우저 특정 요소의 종류와 속성을 채택하였지만 동시에 스타일시트에 찬성하는 세력의 반대로 넷스케이프의 시각적 마크업 기능을 단계적으로 제거하기로 했다. HTML 4는 ISO 8879 - SGML에 따른 SGML 응용 프로그래밍 언어다.[17]
1998년 4월
HTML 4.0[18]

이 버전이 증가되지 않고 조금 수정되어 재발표되었다.

1999년 12월
HTML 4.01[19]

이 W3C 권고안으로 출시되었다. HTML 4.0과 마찬가지로 세 가지 문서 형태를 제공한다. 그리고 2001년 5월 12일에 그것에 대한 최종 오류 수정 사항 이 발표되었다.

2000년 5월
ISO/IEC 15445:2000[20]

[21] ("ISO HTML", HTML 4.01 Strict 기반)이 ISO/IEC 국제 표준과 함께 출시되었다. ISO에서 이 표준안은 ISO/IEC JTC1/SC34 (ISO/IEC 공동 기술 위원회 1, 소위원회 34 - 문서 표현과 처리 언어)의 범위에서 떨어져 나왔다.[20]

2008년 중반, HTML 4.01과 ISO/IEC 15445:2000은 HTML의 대부분의 최근 버전이다. XML 기반 병렬 개발 언어인 XHTML을 통해 W3C의 HTML 작업 그룹은 2000년대 초중반에 성장하였다.

HTML 초안 버전 스케줄

[편집]
1991년 10월
HTML 요소[4]: 비공식적 CERN 문서에서 12개의 HTML 태그 목록이 대중에게 언급되었다.
1992년 7월
6단계 이후의 개정판과 함께 HTML DTD,[1] Archived 2010년 11월 20일 - 웨이백 머신의 첫 번째 비공식 초안
1992년 11월
HTML DTD 1.1 (1.0 대신에 1.1을 RCS 체계를 기반으로 하는 첫 번째 버전 번호로 시작한다.), 비공식 초안
1993년 6월
하이퍼텍스트 마크업 언어[22]는 인터넷 초안(표준에 대한 간략한 제안)과 함께IETFIIIR 작업 그룹에 의하여 발표되었다. 그것은 한 달 후 IETF에 의해 [2] 6가지 추가 초안을 더한 두 번째 버전 [3]으로 대체되었고 결국 HTML 2.0이 RFC1866을 주도했다.
1993년 11월
HTML+가 인터넷 초안과 함께 IETF에 의하여 출시되었고, HTML 초안과의 경쟁을 제안하였다. 1994년 5월 HTML+는 만료되었다.
1995년 4월 (1995년 3월에 저술)
HTML 3.0[23] 이 IETF 표준안으로 제안되었지만 이 제안은 이후 5개월 동안 진전이 없어서 만료되었다. 여기에는 데이브 라겟의 HTML+ 제안의 표와 복잡한 수학적 수식을 표시를 지원하는 것과 같은 특성의 상당부분을 포함했다.[24]
W3C는 HTML3와 CSS를 지원하는 시험하기 위하여 자체적으로 아레나 브라우저를 개발하기 시작했다. 하지만 HTML 3.0은 여러 이유로 성공하지 못했다.
2008년 1월
HTML 5[25] 초안 작업은 W3C에 의해 발표되었다.
비록 문법은 SGML의 문법과 밀접하게 연관되어 있지만, HTML 5는 난해한 SGML 문법과 호환되지 않는다. 그리고 HTML 5를 "html" 시리즈라고 명시적으로 정의되었다.[26]

XHTML 버전

[편집]

XHTML은 XML 1.0을 이용하여 HTML 4.01을 새로 만든 독립된 언어다.

  • XHTML 1.0[27] 은 2000년 1월 26일에 W3C 권고안으로 발표되었다. 이후 2002년 8월 1일에 개정과 재발표를 하였다. 이것은 XML에 관하여 새로 작성된 HTML 4.0 과 HTML 4.01 같이 세가지 문서 형태를 사소한 규약과 함께 제공한다.
  • XHTML 1.1[28] 2001년 5월 31일에 W3C 권고안으로 발표되었다. 그것은 XHTML 1.0 strict 기반이지만 사소한 변경 사항과 사용자 정의 기능을 포함하고, XHTML의 모듈화 으로부터 모듈을 이용하여 새로 작성되었다.
  • XHTML 2.0[29] 은 아직까지 W3C 작업 초안이다. W3C는 2009년 말까지 XHTML 2 그룹을 중단한다고 발표하였다.[30]. 그러므로 XHTML 2.0 표준은 사라질 것이다. XHTML은 XHTML 1.x와 호환되지 않는다. 따라서 XHTML 1.0에서 업데이트된 것 보다 XHTML을 기반으로 하는 새로운 언어가 특성이 더 정확해진다.
  • XHTML5는 HTML 5 초안에서 HTML 5와 함께 정의되었다.[31]

마크업

[편집]
HTML 4 구문 강조

HTML 마크업은 HTML 요소(엘리먼트, Elements)와 그들의 속성(Attributes)과 문자 기반 데이터 형태문자 참조엔티티 참조를 포함하는 몇 가지 핵심 구성 요소로 이루어져 있다. 또 다른 중요한 구성 요소로는 문서 형식 정의(DTD, Document Type Definition)를 명시하는 문서 형식 선언(document type declaration)이다. 차기 HTML 5에서는 DTD를 지정하지 않아도 되고 오직 레이아웃 모드로 지정된다 [4].

Hello world 프로그램프로그래밍 언어스크립트 언어 그리고 마크업 언어를 비교하기 위해 사용되는 일반적인 컴퓨터 프로그램이다. 그리고 HTML에서의 Hello world 프로그램은 단 9줄에 불과하다:

<!doctype html>
<html>
  <head>
    <title>Hello HTML</title>
  </head>
  <body>
    <p>Hello World!</p>
  </body>
</html>

(<html>과 </html>사이의 문자는 웹 페이지를 표현한다. <body>와 </body>사이의 문자는 표시되는 페이지의 내용이며, <head>와 </head>사이의 문자는 눈에는 보이지 않지만 웹 페이지를 표현하기 위해 필요한 해더 정보를 담고 있다.<title>과 </title>사이의 문자는 웹 브라우저의 페이지 제목을 정의하는데 사용된다.)
Hello world 프로그램을 최대로 짧게 만들고 싶다면:

Hello world

이라고 해도 되지만, 웹 표준에 위배된다.이 문서 형식 정의HTML 5이다. 만약 <!doctype html>로 선언하지 않은 경우 대다수의 브라우저는 "쿽스 모드"로 렌더링한다.[32]

HTML 요소

[편집]

HTML 문서는 완전한 HTML 요소로 구성되어 있고, HTML 요소의 가장 보편적인 형태는 세 가지 구성 요소를 가진다: "시작 태그"(Start Tag)와 "종료 태그"(End Tag) 와 같은 태그 한 쌍; 몇 가지 요소 속성은 그 태그들 내에서 특성을 부여한다. 마지막으로 문자와 그래픽 정보 콘텐츠를 화면에 표현한다.

HTML 요소는 태그의 사이와 포함되는 모든 것이다. 태그는 꺾쇠괄호(<>)로 둘러싸인 키워드이다.

HTML 요소의 일반적인 형태

[편집]
<tag>보이는 내용</tag>

HTML 요소의 이름은 태그의 이름이다. 그리고 종료 태그의 이름은 슬래시 문자 ("/")로 시작된다.

HTML 요소의 가장 보편적인 형태

[편집]
<tag attribute1="value1" attribute2="value2">보이는 내용</tag>

속성이 주어지지 않는다면 시작 태그의 기본값을 사용하게 된다.

태그의 기본적인 형태

[편집]

HTML의 머리부분 (<head>...</head>), 보통 제목은 <head>의 안에 포함된다. 예제:

<head>
<title>제목</title>
</head>

단락 구획

[편집]
<p>단락 1</p> <p>단락 2</p>

새 줄(<br>), <br> 와 <p> 간의 차이점은 'br'은 페이지의 의미론적 구조를 변경하지 않는 줄바꿈(breaks a line)인 반면 'p'는 단락으로 페이지를 구분한다.

<code><p>이것은 <br /> 줄바꿈을 <br /> 포함하는 <br /> 단락이다. </p></code>

주석 사용

[편집]
<!--..설명!..-->

주석은 코딩을 이해하는데 도움을 줄 수 있지만 웹 페이지에는 표시되지 않는다.

HTML에서 사용되는 마크업 요소의 형태

[편집]
  • 구조적 마크업은 본문의 목적을 표현한다. 예를 들어, <h2>골프</h2>는 "골프"를 두 번째 수준의 제목으로 규정한다. 그리고 그것은 브라우저에서 이 장의 처음에 나오는 HTML 마크업 제목과 유사한 방식으로 해석될 것이다. 구조적 마크업은 어떤 특정한 렌더링을 표시하지 않지만, 대부분의 웹 브라우저는 요소 포맷팅에 대한 기본적인 스타일을 표준화했다. 텍스트는 캐스캐이딩 스타일시트(CSS)로 더 꾸밀 수 있다.
  • 표현적 마크업은 기능에 관계없이 본문의 외관을 표현한다. 예를 들어, <b>굵은 글씨</b>는 시각적 결과 장치가 굵은 글씨 속에 있는 "boldface"를 해석해야 한다는 것을 지시하지만, 이것을 할 수 있는 장치가 무엇을 해야 할 지(예를 들어 텍스트를 크게 읽어주는 장치와 같은 )에 대한 어떠한 지시도 하지 않는다. <b>굵게</b><i>이탤릭</i>과 같은 경우에는 보통 시각적 해석에 필적하는 여러 가지 요소가 있지만, 본래가 더 의미론적이다. 즉, 각각 <strong>strong emphasis</strong><em>emphasis</em>같이 할 수 있다. 음성 사용자 에이전트가 어떻게 후자의 두 요소를 해석하는 지 지켜보는 것은 쉽다. 그러나 그것은 그들의 표현 상대와 맞먹지는 않는다. 예를 들자면 책의 이름을 강조하는 것이 스크린을 읽는 유저에게는 바람직하지 않지만, 화면에서 그러한 이름이 이탤릭체로 될 것이다. 대부분의 표현 마크업 요소는 스타일 디자인에 근거한 CSS에 호응해서 HTML 4.0 스펙에서는 받아들여지지 않을 것이다.
  • 하이퍼텍스트 마크업은 다른문서와 연결시켜주는 문서의 부분이다. XHTML 1.1 버전을 통한 HTML은 본문속에서 하이퍼링크를 생성하기 위해 anchor 요소(<a>위키백과</a>)의 사용을 필요로 한다. 덧붙여, href 속성은 반드시 정확한 URL을 설정해야만 한다. 예를 들어, HTML 마크업인 <a href="https://ko.wikipedia.org/">한국어 위키백과</a>하이퍼링크로써 "한국어 위키백과"처럼 보일 것이다.
    • 하이퍼링크로써 이미지를 표현하는 예제
      <a href="http://example.org"><img src="image.gif" alt="alternative text" width="50" height="50"></a>
      

주요 HTML 요소들

[편집]
<br>
줄바꾸기
<p>
단락바꾸기(한줄 떨어짐)
<hr>
가로줄
<center>...</center>
...을 가운데 정렬
<font>...</font>
...의 폰트를 바꿈
<ul><li>...<li>...</ul>
...을 순서없는 목록으로 만듦(기본: 까만동그라미)
<ol><li>...<li>...</ol>
...을 순서있는 목록으로 만듦(기본: 숫자)
<table></table>
표만들기
<tr></tr>
행(<table>...</table>...에 넣는다)
<td></td>
열(<tr>...</tr> ...에 넣는다)
<td colspan=숫자></td>
그 셀부터 숫자만큼의 오른쪽 셀을 병합한다
<td rowspan=숫자></td>
그셀부터 숫자만큼의 아래쪽 셀을 병합한다

속성

[편집]

대부분의 요소 속성들은 이름-값 형태이고, "="로 구분하고, 요소의 시작 태그 안에서 요소의 이름 다음에 쓰인다. 값은 외따옴표 또는 쌍따옴표로 둘러쌀 수 있다. 비록 어떤 문자로 구성된 값들이 HTML에서 인용부호 없이 사용될 수도 있지만(XHTML에서는 허용되지 않음), 그 값은 따옴표나 쌍따옴표 또는 쌍 인용부호로 둘러쌀 수 있다.[33][34] 인용부호를 사용하지 않고, 속성값을 사용하는 것은 안전하지 않다.[35] 이름값 쌍 속성과 대조하여, 요소 태그의 시작에 단순히 그 존재만으로도 영향을 끼칠 수 있는 태그가 있다.[4][37]

대부분의 요소는 몇 가지 일반적인 속성을 가질 수 있다.

  • id 속성은 요소에 대한 문서 전체의 고유 식별자를 제공한다. 이것은 스타일시트에 의해 외관적인 특성을 제공하고, 브라우저에 의해 특정 요소를 처리하거나 스크립트에 의해 요소의 내용이나 외관을 바꿀 수 있다. 페이지의 URL에 달려 있는 것처럼, 보통 페이지 다음에 오는 요소에 대한 세계에서 유일한 식별자를 부여한다. 예를 들어, https://en.wikipedia.org/wiki/HTML#Attributes 에 있는 ID 속성과 같다.
  • class 속성은 유사한 요소를 분류하는 방법을 제공한다. 이것은 어휘적 또는 표현적 목적으로 사용될 수 있다. 예를 들어, 어휘적으로 분류는 미세 포맷에 사용된다. 표현적 목적으로 HTML 문서는 class="notation"과 같은 지정자에서, 이 class 값을 갖는 모든 요소는 문서의 주 텍스트에 종속된다는 것을 지시한다. 이러한 요소는 HTML 소스에서 나타났던 장소에 나타나는 대신에 함께 모여서 페이지에서 각주와 같이 표현된다.
  • 작성자는 특정 요소에 표현적 속성을 지닌 style 비 속성 코드를 사용할 것이다. 단순하고, 특정한 또는 특수한 스타일 속성을 가진 애플리케이션에서는 너무 성가시긴 하지만, 스타일시트로 속성을 선택할 때는 요소의 idclass 속성을 사용하는 것이 더 낫다고 간주된다.
  • title 속성은 요소에서 숨겨진 뜻을 설명하는 글을 첨부하는 곳에 사용된다. 대부분의 브라우저의 이 속성은 자주 툴팁과 같이 참조하는 것처럼 보인다.

단축 요소(abbr)는 아래와 같이 다양한 속성을 설명하는데 쓰일 수 있다:

<abbr id="anId" class="aClass" style="color:blue;" title="하이퍼텍스트 마크업 언어">HTML</abbr>

이 예제는 대부분의 브라우저에서 HTML처럼 보인다. 이 단축에 커서를 가리키면 그 제목인 "하이퍼텍스트 마크업 언어"가 보일 것이다.

대부분의 요소 또한 언어와 관련된 속성인 langdir을 취한다.

데이터 형식

[편집]

HTML은 스크립트 데이터와 스타일시트 데이터, 그리고 ID, 이름, URI, 숫자 길이의 단위, 언어, 미디어 기술자, 색상, 문자 인코딩, 날짜와 시간 등을 포함하는 속성 값의 종류를 위한 몇 가지 데이터 형태를 정의 내린다. 이러한 모든 데이터 형식은 문자 데이터를 최적화하기 위하여 분리되었다.

문서 형식 선언

[편집]

HTML 문서는 문서 형식 선언 (비공식적으로, "doctype")으로 시작해야 한다. 브라우저에서 doctype의 기능은 렌더링 모드를 지시하는 것이며, 부분적으로는 쿼크 모드를 피하기 위한 목적도 있다.

doctype의 원래의 목적은 문서 형식 정의 (DTD)에 기반한 SGML 도구를 통하여 HTML 문서의 파싱과 유효 여부 확인을 가능하게 하려는 것이었다. DOCTYPE에 대한 DTD는 DTD에 순응하는 문서를 가진 허용 또는 금지된 내용을 지정하고 기계가 읽을 수 있는 문법을 포함하도록 지시한다. 반면 브라우저는 HTML을 SGML의 애플리케이션으로 수행하지 않으며, 결과적으로 DTD를 읽지 않는다. HTML 5는 기술적인 제한으로 인해 DTD를 정의하지 않는다. 그래서 HTML5에서 doctype 선언 <!doctype html>는 DTD를 참조하지 않는다.

HTML 4 doctype의 예제는 다음과 같다.

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">

이런 선언은 엄격한 HTML 4.01을 만들기 위해 DTD를 참조한다. 이것은 선언적인 요소인 font 같은 요소는 포함하지 않으며, CSS나 span, div 요소는 유지한다. SGML 기반의 유효 확인자(validator)들은 문서를 적절히 해석하거나, 유효 여부 확인을 실행하기 위해 DTD를 읽는다.

최근의 브라우저에서 이 doctype은 쿼크 모드에 반대되는 표준 모드를 활성화한다.

게다가 HTML 4.01은 임시적이고 프레임 단위의 DTD를 제공한다.

시맨틱 웹

[편집]

전송

[편집]

HTML 문서를 다른 컴퓨터 파일과 같은 방법으로 전송할 수 있다. 하지만 HTML 문서들은 대부분 웹 서버에 의한 HTTP나 또는 이메일을 통하여 전송된다.

HTTP

[편집]

월드 와이드 웹은 주로 웹 서버에서 하이퍼텍스트 전송 프로토콜 (HTTP)을 이용하는 웹 브라우저로 전송되는 HTML 문서를 위해 고안되었다. 그러나 HTTP는 HTML 이외에도 이미지나 소리, 그리고 기타 내용물을 서비스하는 데 사용된다. 브라우저가 받는 각 문서를 어떻게 다른지 알려주게 하기 위해, 다른 정보가 문서와 함께 전송된다.

메타데이터는 보통 MIME 타입 (예, text/html or application/xhtml+xml)과 문자 인코딩을 포함한다. (HTML에서 문자 인코팅 참조)

최근의 브라우저에서 HTML 문서와 함께 전송되는 MIN 타입은 문서가 초기에 어떻게 해석해야 하는 지에 대한 영향을 끼칠 것이다. XHTML MIME 타입과 함께 전송된 문서는 잘 구성된 XML로 기대되며, 문법 오류는 브라우저가 그것을 해석하지 못하게 할 것이다. HTML MIME 타입과 함께 전송된 동일 문서가 HTML에 관대한 브라우저에서는 성공적으로 출력될 것이다.

W3C 권고안에서는 권고안 부록 C에 나오는 가이드라인을 따르는 XHTML 1.0 문서는 MIME 타입으로 표시될 것이다.[38] 현재의 XHTML 1.1 작업 초안은 또한 XHTML 1.1 문서는 MIME 타입으로 표시될 것이라고 언급하고 있다.[39][40]

HTML 전자 우편

[편집]

대부분의 그래픽 이메일 클라이언트는 단순 텍스트로는 불가능한 어휘적 마크업과 형식을 제공하기 위해 종종 정의되지 않는 HTML 부분집합 사용을 허용한다. 이것은 색상 제목, 강조, 인용문, 인라인 이미지와 도표와 같은 인쇄정보를 포함한다. 그러한 많은 클라이언트들은 HTML 이메일 메시지를 작성하는 GUI 편집기와 그것을 해석하여 보여주기 위한 렌더링 엔진을 포함한다. 그러나 전자 메일에서 HTML를 포함시키는 것은 호환성 문제와 관련되어 있기 때문에 논쟁의 대상이 된다. 그 이유는 피싱 공격의 은닉을 도와줄 수 있고, 스팸 필터를 혼동시킬 수 있으며, 또한 단순 텍스트보다 크기가 더 커지기 때문이다.

명명 규칙

[편집]

웹 문서의 가장 일반적인 파일 확장자.html이다. 일반적으로 줄여서 .htm라고도 하며, DOSFAT와 같은 초기 운영 체제파일 시스템이 파일 확장자를 3자로 제한했기 때문이다.

HTML 애플리케이션

[편집]

HTML 애플리케이션 (HTA; 파일 확장자 ".hta")는 애플리케이션의 그래픽 인터페이스를 제공하기 위해 브라우저에서 HTML과 DHTML을 사용하는 윈도우용 애플리케이션이다.

정상적인 HTML 파일은 웹 서버와 통신하면서, 웹페이지 객체와 HTTP 쿠키만 다루는 웹 브라우저의 보안 모델에 제한된다. HTA는 완벽히 신뢰된 애플리케이션으로 동작하기 때문에 파일의 생성/편집/제거와 윈도우 레지스트리 엔트리에 보다 더 많은 특권을 가진다. 그 까닭은 그것은 브라우저의 보안 모델 외부에서 작동하기 때문이다. HTA는 HTTP를 경유하여 실행되지 않지만, 실행 파일과 같이 다운로드가 될 수 있으며, 로컬 파일 시스템에서 실행된다.

위지위그 편집기

[편집]

몇 가지 위지위그(What You See Is What You Get, WYSIWYG) 편집기는 HTML 문서를 그래픽 사용자 인터페이스를 이용하여 직관적으로 나타내고 편집기가 HTML 문서로 생성하여 더 이상 사용자가 HTML에 대한 광대한 지식을 가질 필요가 없게 되었다.

웹 페이지 편집은 위지위그 편집 방식이 압도적으로 우위에 있었다. 하지만 이 방식은 생성된 코드의 질이 낮았고 위지윔(What Your See IS What You Mean, WYSIWIM)방식으로의 변화를 옹호하는 목소리 늘어났기 때문에 비난을 받았었다.[41][42]

위지위그 편집기는 다음과 같은 결함 때문에 논쟁의 여지가 있는 논제이다.

  • 주로 의미와는 상반된 레이아웃에 의존하며, 종종 의도된 의미를 전달하지 않고, 단순히 레이아웃을 복사만 하는 마크업을 사용한다.[43]
  • 종종 HTML의 케스케이딩 성질과 CSS를 사용하지 못하게 하는 잡다하고 중복되는 코드를 생성한다.
  • 종종 태그 수프라고 불리는 비문법적인 마크업을 생성한다.
  • HTML 문서의 많은 정보는 레이아웃에 있는 것이 아니기 때문에 그러한 모델은 그것의 위지위그 본질에 대해 비난을 받아왔다.[44]

그럼에도 불구하고 위지위그 편집기가 페이지를 작성하는데 편리함을 제공할 뿐만 아니라 저자들의 HTML에 대한 상세한 전문적 지식을 요구하지 않기 때문에 여전히 위지위그 방식이 웹 저작을 지배하고 있다.

예제

[편집]
<!DOCTYPE html>
<html>
  <head>
    <title> Hello World</title>
  </head>
  <body>
    <p> Hello World </p>
  </body>
</html>

Hello World를 타이틀, 메인페이지에 출력하기.

같이 보기

[편집]

각주

[편집]
  1. HTML 4 — Conformance: requirements and recommendations
  2. Tim Berners-Lee, "Information Management: A Proposal." CERN (1989년 3월, 1990년 5월). W3.org
  3. 팀 버너리, "Design Issues"
  4. “Tags used in HTML”. 월드와이드웹 컨소시엄. 1992년 11월 3일. 2010년 3월 7일에 확인함. 
  5. “First mention of HTML Tags on the www-talk mailing list”. 월드와이드웹 컨소시엄. 1991년 10월 29일. 2013년 5월 17일에 원본 문서에서 보존된 문서. 2010년 3월 3일에 확인함. 
  6. “Index of elements in HTML 4”. 월드와이드웹 컨소시엄. 1999년 12월 24일. 2010년 3월 3일에 확인함. 
  7. 팀 버너스리 (1991년 12월 9일). “Re: SGML/HTML docs, X Browser (archived www-talk mailing list post)”. 2013년 5월 20일에 원본 문서에서 보존된 문서. 2010년 3월 7일에 확인함. SGML은 매우 일반적입니다. HTML은 간단한 구조를 가진 하이퍼텍스트 문서에 적용된 SGML 기본 구문의 응용입니다. 
  8. Raymond, Eric. 〈IETF and the RFC Standards Process〉. 《The Art of Unix Programming》. 2005년 3월 17일에 원본 문서에서 보존된 문서. 2010년 3월 12일에 확인함. In IETF tradition, standards have to arise from experience with a working prototype implementation — but once they become standards, code that does not conform to them is considered broken and mercilessly scrapped. …Internet-Drafts are not specifications, and software implementers and vendors are specifically barred from claiming compliance with them as if they were specifications. Internet-Drafts are focal points for discussion, usually in a working group… Once an Internet-Draft has been published with an RFC number, it is a specification to which implementers may claim conformance. It is expected that the authors of the RFC and the community at large will begin correcting the specification with field experience. 
  9. “HTML+ Internet-Draft - Abstract”. 2016년 5월 15일에 원본 문서에서 보존된 문서. 2007년 6월 17일에 확인함. Browser writers are experimenting with extensions to HTML and it is now appropriate to draw these ideas together into a revised document format. The new format is designed to allow a gradual roll over from HTML, adding features like tables, captioned figures and fill-out forms for querying remote databases or mailing questionnaires. 
  10. “RFC 1866: Hypertext Markup Language - 2.0 - Acknowledgments”. Internet Engineering Task Force. 2005년 9월 22일. 2005년 3월 5일에 원본 문서에서 보존된 문서. 2007년 6월 16일에 확인함. Since 1993, a wide variety of Internet participants have contributed to the evolution of HTML, which has included the addition of in-line images introduced by the NCSA Mosaic software for WWW. Dave Raggett played an important role in deriving the forms material from the HTML+ specification. Dan Connolly and Karen Olson Muldrow rewrote the HTML Specification in 1994. The document was then edited by the HTML working group as a whole, with updates being made by Eric Schieler, Mike Knezovich, and Eric W. Sink at Spyglass, Inc. Finally, Roy Fielding restructured the entire draft into its current form. 
  11. “RFC 1866: Hypertext Markup Language - 2.0 - Introduction”. Internet Engineering Task Force. 2005년 9월 22일. 2005년 3월 5일에 원본 문서에서 보존된 문서. 2007년 6월 16일에 확인함. This document thus defines an HTML 2.0 (to distinguish it from the previous informal specifications). Future (generally upwardly compatible) versions of HTML with new features will be released with higher version numbers. 
  12. Raggett, Dave (1998). 《Raggett on HTML 4》. 2007년 7월 9일에 확인함. 
  13. “HTML 3.2 Reference Specification”. World Wide Web Consortium. 1997년 1월 14일. 2010년 3월 3일에 확인함. 
  14. “IETF HTML WG”. 2007년 6월 16일에 확인함. 주: 이 작업그룹은 폐쇄되었다. 
  15. “HTML 4.0 Specification”. W3C. 1997년 12월 18일. 2010년 3월 4일에 확인함. 
  16. Arnoud Engelfriet. “Introduction to Wilbur”. Web Design Group. 2007년 6월 16일에 확인함. 
  17. “HTML 4 - 4 Conformance: requirements and recommendations”. 2010년 3월 4일에 확인함. 
  18. “HTML 4.0 Specification”. W3C. 1998년 4월 24일. 2010년 3월 12일에 확인함. 
  19. “HTML 4.01 Specification”. World Wide Web Consortium. 1999년 12월 24일. 2010년 3월 4일에 확인함. 
  20. ISO (2000). “ISO/IEC 15445:2000 - Information technology -- Document description and processing languages -- HyperText Markup Language (HTML)”. 2010년 3월 12일에 확인함. 
  21. CS.TCD.ie
  22. Hypertext Markup Language: A Representation of Textual Information and MetaInformation for Retrieval and Interchange
  23. “HTML 3.0 Draft (Expired!) Materials”. World Wide Web Consortium. 1995년 12월 21일. 2010년 3월 4일에 확인함. 
  24. “HyperText Markup Language Specification Version 3.0”. 2007년 6월 16일에 확인함. 
  25. “HTML 5”. World Wide Web Consortium. 2008년 6월 10일. 2010년 3월 4일에 확인함. 
  26. “HTML 5, one vocabulary, two serializations”. 2010년 3월 4일에 확인함. 
  27. “XHTML 1.0: The Extensible HyperText Markup Language (Second Edition)”. 월드와이드웹 컨소시엄. 2000년 1월 26일. 2010년 3월 7일에 확인함. 
  28. “XHTML 1.1 - Module-based XHTML - Second Edition”. 월드와이드웹 컨소시엄. 2007년 2월 16일. 2010년 3월 7일에 확인함. 
  29. “XHTML 2.0”. 월드와이드웹 컨소시엄. 2006년 7월 26일. 2010년 3월 7일에 확인함. 
  30. “XHTML 2 Working Group Expected to Stop Work End of 2009, W3C to Increase Resources on HTML 5”. 월드와이드웹 컨소시엄. 2009년 7월 17일. 2010년 3월 7일에 확인함. 
  31. “HTML 5”. 월드와이드웹 컨소시엄. 2008년 10월 24일. 2010년 3월 7일에 확인함. 
  32. Activating Browser Modes with Doctype
  33. “On SGML and HTML”. 월드와이드웹 컨소시엄. 2010년 3월 7일에 확인함. 
  34. “XHTML 1.0 - Differences with HTML 4”. 월드와이드웹 컨소시엄. 2010년 3월 7일에 확인함. 
  35. Korpela, Jukka (1998년 7월 6일). “Why attribute values should always be quoted in HTML”. Cs.tut.fi. 2008년 11월 21일에 원본 문서에서 보존된 문서. 2010년 3월 7일에 확인함. 
  36. “Objects, Images, and Applets in HTML documents”. 월드와이드웹 컨소시엄. 1999년 12월 24일. 2010년 3월 7일에 확인함. 
  37. img 요소에서[36] ismap 속성과 같이.
  38. “XHTML 1.0 The Extensible HyperText Markup Language (Second Edition)”. World Wide Web Consortium. 2000. 2008년 12월 7일에 확인함. XHTML Documents which follow the guidelines set forth in Appendix C, "HTML Compatibility Guidelines" may be labeled with the Internet Media Type "text/html" [RFC2854], as they are compatible with most HTML browsers. Those documents, and any other document conforming to this specification, may also be labeled with the Internet Media Type "application/xhtml+xml" as defined in [RFC3236]. 
  39. “RFC 2119: Key words for use in RFCs to Indicate Requirement Levels”. Harvard University. 1997. 2008년 12월 6일에 원본 문서에서 보존된 문서. 2008년 12월 7일에 확인함. 3. SHOULD This word, or the adjective "RECOMMENDED", mean that there may exist valid reasons in particular circumstances to ignore a particular item, but the full implications must be understood and carefully weighed before choosing a different course. 
  40. “XHTML 1.1 - Module-based XHTML - Second Edition”. World Wide Web Consortium. 2007. 2008년 12월 7일에 확인함. XHTML 1.1 documents SHOULD be labeled with the Internet Media Type text/html as defined in [RFC2854] or application/xhtml+xml as defined in [RFC3236]. 
  41. Sauer, C.: WYSIWIKI - Questioning WYSIWYG in the Internet Age. In: Wikimania (2006)
  42. Spiesser, J., Kitchen, L.: Optimization of html automatically generated by WYSIWYG programs. In: 13th International Conference on World Wide Web, pp. 355--364. WWW '04. ACM, New York, NY (New York, NY, USA, May 17-20, 2004)
  43. “XHTML Reference: blockquote”. 2010년 3월 25일에 원본 문서에서 보존된 문서. 2010년 3월 12일에 확인함. 
  44. Doug Engelbart's INVISIBLE REVOLUTION

외부 링크

[편집]