XHTML-퀵 가이드
XHTML은 E를 의미합니다.X지속성 HyperT내선 M아크 업 L고뇌. 인터넷 진화의 다음 단계입니다. XHTML 1.0은 XHTML 제품군의 첫 번째 문서 유형입니다.
XHTML은 HTML 4.01과 거의 동일하지만 차이점이 거의 없습니다. 이것은 HTML 4.01의 더 깨끗하고 엄격한 버전입니다. 이미 HTML을 알고 있다면이 최신 버전의 HTML을 배우는 데 거의주의를 기울일 필요가 없습니다.
XHTML은 웹 개발자가 HTML에서 XML로 전환 할 수 있도록 W3C (World Wide Web Consortium)에서 개발했습니다. 지금 XHTML로 마이그레이션함으로써 웹 개발자는 콘텐츠의 이전 버전과 향후 호환성에 대한 확신을 유지하면서 모든 이점을 갖춘 XML 세계로 들어갈 수 있습니다.
왜 XHTML을 사용합니까?
콘텐츠를 XHTML 1.0으로 마이그레이션하는 개발자는 다음과 같은 이점을 얻습니다.
XHTML 문서는 표준 XML 도구를 사용하여 쉽게보고, 편집하고, 유효성을 검사하므로 XML을 준수합니다.
XHTML 문서는 기존 브라우저와 새 브라우저에서 이전보다 더 잘 작동하도록 작성할 수 있습니다.
XHTML 문서는 HTML 문서 개체 모델 또는 XML 문서 개체 모델에 의존하는 스크립트 및 애플릿과 같은 응용 프로그램을 활용할 수 있습니다.
XHTML은 현재와 미래의 웹 브라우저에서 웹 페이지를 쉽게 구문 분석하고 처리 할 수 있도록보다 일관되고 잘 구성된 형식을 제공합니다.
장기적으로 문서를 쉽게 유지, 편집, 변환 및 서식을 지정할 수 있습니다.
XHTML은 W3C의 공식 표준이기 때문에 귀하의 웹 사이트는 많은 브라우저와 더 호환되고 더 정확하게 렌더링됩니다.
XHTML은 HTML과 XML의 장점을 결합합니다. 또한 XHTML 페이지는 모든 XML 지원 브라우저에서 렌더링 할 수 있습니다.
XHTML은 웹 페이지의 품질 표준을 정의하며이를 준수하면 웹 페이지가 품질 웹 페이지로 간주됩니다. W3C는 품질 스탬프로 해당 페이지를 인증합니다.
웹 개발자와 웹 브라우저 디자이너는 새로운 마크 업 언어를 통해 아이디어를 표현할 수있는 새로운 방법을 끊임없이 찾고 있습니다. XML에서 새로운 요소 나 추가 요소 속성을 도입하는 것은 비교적 쉽습니다. XHTML 제품군은 XHTML 모듈과 새로운 XHTML 호환 모듈을 개발하기위한 기술을 통해 이러한 확장을 수용하도록 설계되었습니다. 이러한 모듈은 콘텐츠를 개발하고 새로운 사용자 에이전트를 설계 할 때 기존 기능과 새로운 기능을 결합 할 수 있습니다.
기본 이해
계속 진행하기 전에 HTML, XML 및 SGML이 무엇인지 간략히 살펴 보겠습니다.
SGML이란 무엇입니까?
이것은 STandard G활기차게 M아크 업 L국제 표준 ISO 8879를 준수하는 anguage (SGML) 응용 프로그램입니다. HTML은 World Wide Web의 표준 게시 언어로 널리 알려져 있습니다.
특히 전자 문서 교환, 문서 관리 및 문서 게시에 사용되는 마크 업 언어를 설명하는 언어입니다. HTML은 SGML에 정의 된 언어의 예입니다.
XML이란 무엇입니까?
XML은 E를 의미합니다.X지속성 M아크 업 L고뇌. XML은 HTML과 매우 유사한 마크 업 언어이며 데이터를 설명하도록 설계되었습니다. XML 태그는 미리 정의되어 있지 않습니다. 필요에 따라 고유 한 태그를 정의해야합니다.
XHTML 구문은 HTML 구문과 매우 유사하며 거의 모든 유효한 HTML 요소가 XHTML에서도 유효합니다. 그러나 XHTML 문서를 작성할 때는 HTML 문서가 XHTML과 호환되도록하기 위해 약간의주의를 기울여야합니다.
다음은 새로운 XHTML 문서를 작성하거나 기존 HTML 문서를 XHTML 문서로 변환하는 동안 기억해야 할 중요한 사항입니다.
XHTML 문서의 시작 부분에 DOCTYPE 선언을 작성하십시오.
모든 XHTML 태그와 속성을 소문자로만 작성하십시오.
모든 XHTML 태그를 올바르게 닫습니다.
모든 태그를 올바르게 중첩하십시오.
모든 속성 값을 인용하십시오.
속성 최소화를 금지합니다.
교체 name 속성 id 속성.
비추천 language 스크립트 태그의 속성입니다.
위의 XHTML 규칙에 대한 자세한 설명은 다음과 같습니다.
DOCTYPE 선언
모든 XHTML 문서에는 시작시 DOCTYPE 선언이 있어야합니다. DOCTYPE 선언에는 세 가지 유형이 있으며 XHTML Doctypes 장에서 자세히 설명합니다. 다음은 DOCTYPE을 사용하는 예입니다.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
대소 문자 구분
XHTML은 대소 문자를 구분하는 마크 업 언어입니다. 모든 XHTML 태그 및 속성은 소문자로만 작성해야합니다.
<!-- This is invalid in XHTML -->
<A Href="/xhtml/xhtml_tutorial.html">XHTML Tutorial</A>
<!-- Correct XHTML way of writing this is as follows -->
<a href="/xhtml/xhtml_tutorial.html">XHTML Tutorial</a>
예에서 Href 및 앵커 태그 A 소문자가 아니므로 정확하지 않습니다.
태그 닫기
각각의 모든 XHTML 태그에는 동일한 닫는 태그가 있어야하며 빈 요소에도 닫는 태그가 있어야합니다. 다음은 태그를 사용하는 유효하고 잘못된 방법을 보여주는 예입니다.
<!-- This is invalid in XHTML -->
<p>This paragraph is not written according to XHTML syntax.
<!-- This is also invalid in XHTML -->
<img src="/images/xhtml.gif" >
다음 구문은 XHTML에서 태그 위의 올바른 작성 방법을 보여줍니다. 차이점은 여기에서 두 태그를 올바르게 닫았다는 것입니다.
<!-- This is valid in XHTML -->
<p>This paragraph is not written according to XHTML syntax.</p>
<!-- This is also valid now -->
<img src="/images/xhtml.gif" />
속성 견적
XHTML 속성의 모든 값은 따옴표로 묶어야합니다. 그렇지 않으면 XHTML 문서가 유효하지 않은 문서로 간주됩니다. 다음은 구문을 보여주는 예입니다.
<!-- This is invalid in XHTML -->
<img src="/images/xhtml.gif" width=250 height=50 />
<!-- Correct XHTML way of writing this is as follows -->
<img src="/images/xhtml.gif" width="250" height="50" />
속성 최소화
XHTML은 속성 최소화를 허용하지 않습니다. 이는 속성과 그 값을 명시 적으로 명시해야 함을 의미합니다. 다음 예제는 차이점을 보여줍니다-
<!-- This is invalid in XHTML -->
<option selected>
<!-- Correct XHTML way of writing this is as follows -->
<option selected="selected">
다음은 최소화 된 HTML 속성 목록과 XHTML로 작성하는 데 필요한 방법입니다.
HTML 스타일 | XHTML 스타일 |
---|---|
콤팩트 | compact = "콤팩트" |
확인 | checked = "체크 됨" |
알리다 | 선언 = "선언" |
읽기 전용 | readonly = "읽기 전용" |
장애인 | disabled = "비활성화 됨" |
선택된 | selected = "선택됨" |
연기하다 | defer = "defer" |
ismap | ismap = "ismap" |
Nohref | nohref = "nohref" |
그늘 | noshade = "noshade" |
Nowrap | nowrap = "nowrap" |
배수 | multiple = "다중" |
아니요 | noresize = "noresize" |
ID의 특성
id 속성은 name 속성을 대체합니다. name = "name"을 사용하는 대신 XHTML은 id = "id"를 사용하는 것을 선호합니다. 다음 예는 방법을 보여줍니다-
<!-- This is invalid in XHTML -->
<img src="/images/xhtml.gif" name="xhtml_logo" />
<!-- Correct XHTML way of writing this is as follows -->
<img src="/images/xhtml.gif" id="xhtml_logo" />
언어 특성
스크립트 태그의 언어 속성은 더 이상 사용되지 않습니다. 다음 예는이 차이점을 보여줍니다.
<!-- This is invalid in XHTML -->
<script language="JavaScript" type="text/JavaScript">
document.write("Hello XHTML!");
</script>
<!-- Correct XHTML way of writing this is as follows -->
<script type="text/JavaScript">
document.write("Hello XHTML!");
</script>
중첩 된 태그
모든 XHTML 태그를 올바르게 중첩해야합니다. 그렇지 않으면 문서가 잘못된 XHTML 문서로 간주됩니다. 다음 예제는 구문을 보여줍니다-
<!-- This is invalid in XHTML -->
<b><i> This text is bold and italic</b></i>
<!-- Correct XHTML way of writing this is as follows -->
<b><i> This text is bold and italic</i></b>
요소 금지
다음 요소는 내부에 다른 요소를 포함 할 수 없습니다. 이 금지는 모든 중첩 깊이에 적용됩니다. 의미는 모든 내림차순 요소를 포함합니다.
요소 | 금지 |
---|---|
<a> | 다른 <a> 요소를 포함하지 않아야합니다. |
<프리> | <img>, <object>, <big>, <small>, <sub> 또는 <sup> 요소를 포함해서는 안됩니다. |
<버튼> | <input>, <select>, <textarea>, <label>, <button>, <form>, <fieldset>, <iframe> 또는 <isindex> 요소를 포함해서는 안됩니다. |
<라벨> | 다른 <label> 요소를 포함하지 않아야합니다. |
<양식> | 다른 <form> 요소를 포함해서는 안됩니다. |
최소 XHTML 문서
다음 예제는 XHTML 1.0 문서의 최소 내용을 보여줍니다.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/TR/xhtml1" xml:lang="en" lang="en">
<head>
<title>Every document must have a title</title>
</head>
<body>
...your content goes here...
</body>
</html>
XHTML이 XML 응용 프로그램이라는 사실 때문에 SGML 기반 HTML 4에서 완벽하게 합법적 인 특정 관행을 변경해야합니다. 이전 장에서 이미 XHTML 구문을 보았으므로 XHTML과 HTML의 차이점은 매우 분명합니다. 다음은 XHTML과 HTML의 비교입니다.
XHTML 문서는 올바른 형식이어야합니다.
Well-formedness는 XML이 도입 한 새로운 개념입니다. 본질적으로 이는 모든 요소에 닫는 태그가 있어야하며 올바르게 중첩되어야 함을 의미합니다.
CORRECT: Nested Elements
<p>Here is an emphasized <em>paragraph</em>.</p>
INCORRECT: Overlapping Elements
<p>Here is an emphasized <em>paragraph.</p></em>
요소 및 속성은 소문자 여야합니다.
XHTML 문서는 모든 HTML 요소와 속성 이름에 소문자를 사용해야합니다. XHTML 문서는 XML 문서로 가정되고 XML은 대소 문자를 구분하기 때문에이 차이가 필요합니다. 예를 들어 <li>와 <LI>는 다른 태그입니다.
모든 요소에 끝 태그가 필요합니다.
HTML에서 특정 요소는 종료 태그를 생략 할 수 있습니다. 그러나 XML에서는 종료 태그를 생략 할 수 없습니다.
CORRECT: Terminated Elements
<p>Here is a paragraph.</p><p>here is another paragraph.</p>
<br><hr/>
INCORRECT: Unterminated Elements
<p>Here is a paragraph.<p>here is another paragraph.
<br><hr>
속성 값은 항상 따옴표로 묶어야합니다.
숫자 값을 포함한 모든 속성 값은 따옴표로 묶어야합니다.
CORRECT: Quoted Attribute Values
<td rowspan="3">
INCORRECT: Unquoted Attribute Values
<td rowspan=3>
속성 최소화
XML은 속성 최소화를 지원하지 않습니다. 속성-값 쌍은 전체로 작성해야합니다. compact 및 checked와 같은 속성 이름은 값을 지정하지 않으면 요소에서 발생할 수 없습니다.
CORRECT: Non Minimized Attributes
<dl compact="compact">
INCORRECT: Minimized Attributes
<dl compact>
속성 값의 공백 처리
브라우저가 속성을 처리 할 때 다음을 수행합니다.
선행 및 후행 공백을 제거합니다.
하나 이상의 공백 문자 (줄 바꿈 포함)의 시퀀스를 단일 단어 간 공간에 매핑합니다.
스크립트 및 스타일 요소
XHTML에서 스크립트와 스타일 요소는 "<"및 "&"문자가있는 경우 직접 포함해서는 안됩니다. 그런 다음 마크 업의 시작으로 처리됩니다. "<"및 "&"와 같은 엔티티는 각각 "<"및 "&"문자를 표시하기 위해 XML 프로세서에 의해 엔티티 참조로 인식됩니다.
CDATA 표시 섹션 내에서 스크립트 또는 스타일 요소의 내용을 래핑하면 이러한 엔티티의 확장을 방지 할 수 있습니다.
<script type="text/JavaScript">
<![CDATA[
... unescaped VB or Java Script here... ...
]]>
</script>
대안은 외부 스크립트 및 스타일 문서를 사용하는 것입니다.
ID 및 이름 속성 이있는 요소
XHTML은 name 속성을 id 속성으로 대체 할 것을 권장 합니다. XHTML 1.0에서는 이러한 요소 의 이름 속성이 공식적으로 더 이상 사용되지 않으며 XHTML의 후속 버전에서 제거됩니다.
미리 정의 된 값 세트가있는 속성
HTML과 XHTML에는 둘 다 미리 정의되고 제한된 값 집합이있는 일부 속성이 있습니다. 예를 들면type 의 속성 input요소. HTML 및 XML에서 이들은enumerated attributes. HTML 4에서 이러한 값의 해석은 대소 문자를 구분하지 않았으므로TEXT 다음의 값과 동일했습니다. text.
XHTML에서 이러한 값의 해석은 대소 문자를 구분하므로 이러한 모든 값은 소문자로 정의됩니다.
16 진수 값으로 엔티티 참조
HTML과 XML은 모두 16 진수 값을 사용하여 문자에 대한 참조를 허용합니다. HTML에서 이러한 참조는 다음 중 하나를 사용하여 만들 수 있습니다.&#Xnn; 또는 &#xnn; 유효하지만 XHTML 문서에서는 다음과 같은 소문자 버전 만 사용해야합니다. &#xnn;.
<html> 요소는 필수입니다
모든 XHTML 요소는 <html> 루트 요소 내에 중첩되어야합니다. 다른 모든 요소는 쌍으로 이루어져야하며 상위 요소 내에 올바르게 중첩되어야하는 하위 요소를 가질 수 있습니다. 기본 문서 구조는-
<!DOCTYPE html....>
<html>
<head> ... </head>
<body> ... </body>
</html>
XHTML 표준은 세 가지 문서 유형 정의 (DTD)를 정의합니다. 가장 일반적으로 사용되는 쉬운 문서는 XHTML Transitional 문서입니다.
XHTML 1.0 문서 유형 정의는 3 개의 DTD에 해당합니다.
- Strict
- Transitional
- Frameset
한 DTD에서는 사용할 수 있지만 다른 DTD에서는 사용할 수없는 XHTML 요소와 속성이 거의 없습니다. 따라서 XHTML 문서를 작성하는 동안 XHTML 요소 또는 속성을 신중하게 선택해야합니다. 그러나 XHTML 유효성 검사기는 유효하고 잘못된 요소와 속성을 식별하는 데 도움이됩니다.
이에 대한 자세한 내용은 XHTML 유효성 검사 를 확인하십시오 .
XHTML 1.0 엄격
CSS (Cascading Style Sheet)를 엄격하게 사용하고 대부분의 XHTML 속성을 작성하지 않으려는 경우이 DTD를 사용하는 것이 좋습니다. 이 DTD를 준수하는 문서는 최상의 품질입니다.
XHTML 1.0 Strict DTD를 사용하려면 XHTML 문서 맨 위에 다음 줄을 포함해야합니다.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
XHTML 1.0 전환
Cascading Style Sheet 속성을 거의 사용하지 않고 많은 XHTML 속성을 사용할 계획이라면이 DTD를 채택하고 그에 따라 XHTML 문서를 작성해야합니다.
XHTML 1.0 Transitional DTD를 사용하려면 XHTML 문서 맨 위에 다음 줄을 포함해야합니다.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
XHTML 1.0 프레임 셋
HTML 프레임을 사용하여 브라우저 창을 두 개 이상의 프레임으로 분할하려는 경우이를 사용할 수 있습니다.
XHTML 1.0 Frameset DTD를 사용하려면 XHTML 문서의 맨 위에 다음 줄을 포함해야합니다.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">
Note− XHTML 문서를 작성하는 데 사용하는 DTD가 무엇이든 상관 없습니다. 유효한 XHTML 문서 인 경우 문서는 양질의 문서로 간주됩니다.
표준이며 모든 XHTML / HTML 태그와 관련된 몇 가지 XHTML / HTML 속성이 있습니다. 이러한 속성은 간략한 설명과 함께 여기에 나열되어 있습니다.
핵심 속성
기본, 헤드, html, 메타, 매개 변수, 스크립트, 스타일 및 제목 요소에서는 유효하지 않습니다.
속성 | 값 | 기술 |
---|---|---|
수업 | class_rule 또는 style_rule | 요소의 클래스입니다. |
신분증 | id_name | 요소의 고유 ID입니다. |
스타일 | style_definition | 인라인 스타일 정의. |
표제 | tooltip_text | 마우스 팁에 표시 할 텍스트입니다. |
언어 속성
그만큼 lang속성은 포함 된 콘텐츠에 사용되는 언어를 나타냅니다. 언어는 다음과 같은 ISO 표준 언어 약어를 사용하여 식별됩니다.fr 프랑스어의 경우 en영어 등. 더 많은 코드와 형식은 www.ietf.org에 설명되어 있습니다.
base, br, frame, frameset, hr, iframe, param 및 script 요소에서는 유효하지 않습니다.
속성 | 값 | 기술 |
---|---|---|
dir | ltr | rtl | 텍스트 방향을 설정합니다. |
lang | language_code | 언어 코드를 설정합니다. |
Microsoft 독점 속성
Microsoft는 Internet Explorer 4 이상 버전에 여러 가지 새로운 독점 속성을 도입했습니다.
속성 | 값 | 기술 |
---|---|---|
액세스 키 | 캐릭터 | 요소에 액세스하기위한 키보드 단축키를 설정합니다. |
언어 | 끈 | 이 특성은 일반적으로 이벤트 처리기 특성을 통해 요소에 바인딩 된 관련 스크립트와 함께 사용할 스크립팅 언어를 지정합니다. 가능한 값에는 JavaScript, jScript, VBS 및 VBScript가 포함될 수 있습니다. |
tabindex | 번호 | 요소의 탭 순서를 설정합니다. |
내용 편집 가능 | 부울 | 사용자가 Internet Explorer 5.5 이상에서 렌더링 된 콘텐츠를 편집 할 수 있습니다. 가능한 값은 참 또는 거짓입니다. |
장애인 | 부울 | 비활성화 된 속성이 설정된 요소는 흐리게 표시 될 수 있으며 사용자 입력에 응답하지 않습니다. 가능한 값은 참 또는 거짓입니다. |
숨기기 | 켜짐 또는 꺼짐 | Internet Explorer 5.5에 도입 된이 독점 속성은 요소의 내용에 대한 초점을 숨 깁니다. tabindex 속성을 사용하여 요소에 포커스를 적용해야합니다. |
선택 불가 | 켜짐 또는 꺼짐 | Internet Explorer 5.5에 표시된 콘텐츠가 선택되지 않도록하는 데 사용됩니다. |
사용자가 웹 사이트를 방문하면 텍스트, 이미지 및 하이퍼 링크 클릭, 마우스 오버 등의 작업을 수행합니다. 다음은 JavaScript가 이벤트를 호출하는 예입니다.
JavaScript 또는 VBScript로 이벤트 핸들러를 작성할 수 있으며 이러한 이벤트 핸들러를 이벤트 태그 속성의 값으로 지정할 수 있습니다. XHTML 1.0에는 HTML 4.01 사양에서 사용할 수있는 유사한 이벤트 집합이 있습니다.
<body> 및 <frameset> 레벨 이벤트
문서 수준에서 이벤트가 발생할 때 JavaScript 또는 VBScript 코드를 트리거하는 데 사용할 수있는 속성은 두 개뿐입니다.
속성 | 값 | 기술 |
---|---|---|
길 위에 | 스크립트 | XHTML 문서가로드되면 스크립트가 실행됩니다. |
언로드 | 스크립트 | XHTML 문서가 언로드 될 때 스크립트가 실행됩니다. |
Note − 여기서 스크립트는 VBScript 또는 JavaScript의 모든 기능 또는 코드를 의미합니다.
<form> 레벨 이벤트
양식 레벨에서 이벤트가 발생할 때 JavaScript 또는 VBScript 코드를 트리거하는 데 사용할 수있는 다음 6 개의 속성이 있습니다.
속성 | 값 | 기술 |
---|---|---|
onchange | 스크립트 | 요소가 변경되면 스크립트가 실행됩니다. |
제출시 | 스크립트 | 양식이 제출되면 스크립트가 실행됩니다. |
onreset | 스크립트 | 양식이 재설정되면 스크립트가 실행됩니다. |
onselect | 스크립트 | 요소가 선택되면 스크립트가 실행됩니다. |
onblur | 스크립트 | 요소가 포커스를 잃으면 스크립트가 실행됩니다. |
onfocus | 스크립트 | 요소가 포커스를 받으면 스크립트가 실행됩니다. |
키보드 이벤트
다음 세 가지 이벤트가 키보드에 의해 생성됩니다. 이러한 이벤트는 base, bdo, br, frame, frameset, head, html, iframe, meta, param, script, style 및 title 요소에서 유효하지 않습니다.
속성 | 값 | 기술 |
---|---|---|
onkeydown | 스크립트 | 키를 누르면 스크립트가 실행됩니다. |
onkeypress | 스크립트 | 스크립트는 키를 눌렀다 놓을 때 실행됩니다. |
onkeyup | 스크립트 | 스크립트는 키 해제를 실행합니다. |
기타 이벤트
다음 7 개의 이벤트는 HTML 태그와 접촉 할 때 마우스로 생성됩니다. 이러한 이벤트는 base, bdo, br, frame, frameset, head, html, iframe, meta, param, script, style 및 title 요소에서 유효하지 않습니다.
속성 | 값 | 기술 |
---|---|---|
onclick | 스크립트 | 스크립트는 마우스 클릭으로 실행됩니다. |
ondblclick | 스크립트 | 스크립트는 마우스를 두 번 클릭하면 실행됩니다. |
onmousedown | 스크립트 | 마우스 버튼을 누르면 스크립트가 실행됩니다. |
onmousemove | 스크립트 | 마우스 포인터가 움직일 때 스크립트가 실행됩니다. |
onmouseout | 스크립트 | 마우스 포인터가 요소 밖으로 이동할 때 스크립트가 실행됩니다. |
onmouseover | 스크립트 | 마우스 포인터가 요소 위로 이동하면 스크립트가 실행됩니다. |
onmouseup | 스크립트 | 마우스 버튼을 놓으면 스크립트가 실행됩니다. |
W3C는 잘못된 형식의 비표준 마크 업 시대에서 인터넷 콘텐츠 개발 커뮤니티를 올바른 형식의 유효한 XML 세계로 이동시키는 데 도움이되었습니다. XHTML 1.0에서 이러한 움직임은 기존 HTML 4 (또는 이전) 기반 콘텐츠를 XHTML 및 XML로 쉽게 마이그레이션 할 수 있다는 목표에 따라 조정되었습니다.
W3C는 XHTML 제품군에서 더 이상 사용되지 않는 요소 및 속성에 대한 지원을 제거했습니다. 이러한 요소와 속성에는 스타일 시트 또는 클라이언트 별 기본 동작을 통해 더 잘 처리되는 프레젠테이션 지향 기능이 있습니다.
이제 W3C의 HTML 워킹 그룹은 XHTML 1.1 인 모듈만을 기반으로 초기 문서 유형을 정의했습니다. 이 문서 유형은 광범위한 클라이언트 장치에 이식 할 수 있도록 설계되었으며 대부분의 인터넷 콘텐츠에 적용 할 수 있습니다.
문서 적합성
XHTML 1.1은 다음 기준을 모두 충족해야하는 XHTML 문서를 엄격하게 준수하는 정의를 제공합니다.
문서는 XHTML 1.1 문서 유형 정의에 표현 된 제약 조건을 준수해야합니다.
문서의 루트 요소는 <html>이어야합니다.
문서의 루트 요소는 xmlns 속성을 사용하여 XHTML 네임 스페이스를 지정해야 합니다.
루트 요소는 XML 스키마에 정의 된 스키마 위치 속성도 포함 할 수 있습니다.
루트 요소 이전에 문서에 DOCTYPE 선언이 있어야합니다. 존재하는 경우 DOCTYPE 선언에 포함 된 공용 식별자는 XHTML 1.1 문서 유형 정의에있는 DTD를 참조해야합니다.
다음은 XHTML 1.1 문서의 예입니다.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.w3.org/MarkUp/SCHEMA/xhtml11.xsd" xml:lang="en">
<head>
<title>This is the document title</title>
</head>
<body>
<p>Moved to <a href="http://example.org/">example.org</a>.</p>
</body>
</html>
Note−이 예에서는 XML 선언이 포함되어 있습니다. 위와 같은 XML 선언은 모든 XML 문서에 필요하지 않습니다. XHTML 문서 작성자는 모든 문서에서 XML 선언을 사용하는 것이 좋습니다. 문서의 문자 인코딩이 기본 UTF-8 또는 UTF-16이 아닌 경우 이러한 선언이 필요합니다.
XHTML 1.1 모듈
XHTML 1.1 문서 유형은 다음 XHTML 모듈로 구성됩니다.
Structure Module− 구조 모듈은 XHTML의 주요 구조 요소를 정의합니다. 이러한 요소는 많은 XHTML 제품군 문서 유형의 컨텐츠 모델에 대한 기반으로 효과적으로 작동합니다. 이 모듈에 포함 된 요소와 속성은-body, head, html 및 title입니다.
Text Module −이 모듈은 모든 기본 텍스트 컨테이너 요소, 속성 및 해당 콘텐츠 모델을 정의합니다. − abbr, 약어, 주소, 인용문, br, 인용, 코드, dfn, div, em, h1, h2, h3, h4, h5, h6 , kbd, p, pre, q, samp, span, strong 및 var.
Hypertext Module− 하이퍼 텍스트 모듈은 다른 리소스에 대한 하이퍼 텍스트 링크를 정의하는 데 사용되는 요소를 제공합니다. 이 모듈은 요소 a를 지원합니다.
List Module− 이름에서 알 수 있듯이 목록 모듈은 목록 지향 요소를 제공합니다. 특히 목록 모듈은 dl, dt, dd, ol, ul 및 li과 같은 요소와 속성을 지원합니다.
Object Module− 객체 모듈은 범용 객체 포함을위한 요소를 제공합니다. 특히, Object 모듈은-object 및 param을 지원합니다.
Presentation Module −이 모듈은 간단한 프레젠테이션 관련 마크 업 (b, big, hr, i, small, sub, sup 및 tt)을위한 요소, 속성 및 최소 콘텐츠 모델을 정의합니다.
Edit Module −이 모듈은 편집 관련 마크 업 (del 및 ins)에 사용할 요소와 속성을 정의합니다.
Bidirectional Text Module − 양방향 텍스트 모듈은 요소의 내용에 대한 양방향 규칙을 선언하는 데 사용할 수있는 요소를 정의합니다. − bdo.
Forms Module− HTML 4.0에서 볼 수있는 모든 양식 기능을 제공합니다. 특히-버튼, 필드 셋, 양식, 입력, 레이블, 범례, 선택, optgroup, 옵션 및 텍스트 영역을 지원합니다.
Table Module − 캡션, col, colgroup, table, tbody, td, tfoot, th, thead, tr 등의 요소, 속성, 콘텐츠 모델을 지원합니다.
Image Module− 기본 이미지 임베딩을 제공하며 클라이언트 측 이미지 맵의 일부 구현에서 독립적으로 사용될 수 있습니다. 그것은 요소-img를 지원합니다.
Client-side Image Map Module − 클라이언트 측 이미지 맵 (영역 및 맵)에 대한 요소를 제공합니다.
Server-side Image Map Module− 이미지 선택 및 선택 좌표 전송을 지원합니다. 서버 측 이미지 맵 모듈은-img의 ismap 속성을 지원합니다.
Intrinsic Events Module − XHTML Events에서 논의 된 모든 이벤트를 지원합니다.
Meta information Module− 메타 정보 모듈은 문서의 선언 부분 내에서 정보를 설명하는 요소를 정의합니다. 그것은 요소 메타를 포함합니다.
Scripting Module− 실행 가능한 스크립트 또는 실행 가능한 스크립트 지원 부족과 관련된 정보를 포함하는 데 사용되는 요소를 정의합니다. 이 모듈에 포함 된 요소와 속성은-noscript와 script입니다.
Style Sheet Module− 내부 스타일 시트를 선언 할 때 사용할 요소를 정의합니다. 이 모듈에서 정의한 요소와 속성은 스타일입니다.
Style Attribute Module (Deprecated) − 스타일 속성을 정의합니다.
Link Module− 외부 리소스에 대한 링크를 정의하는 데 사용할 수있는 요소를 정의합니다. 링크 요소를 지원합니다 .
Base Module− 문서의 상대 URI가 해결되는 기본 URI를 정의하는 데 사용할 수있는 요소를 정의합니다. 이 모듈에 포함 된 요소와 속성은 − base 입니다.
Ruby Annotation Module − XHTML은 또한 RUBY에 정의 된 Ruby Annotation 모듈을 사용하고 − ruby, rbc, rtc, rb, rt 및 rp를 지원합니다.
XHTML 1.0 Strict의 변경 사항
이 섹션에서는 XHTML 1.1과 XHTML 1.0 Strict의 차이점에 대해 설명합니다. XHTML 1.1은 HTML 4와 XHTML 1.0 모두에서 벗어난 것을 나타냅니다.
가장 중요한 것은 더 이상 사용되지 않는 기능을 제거하는 것입니다.
변경 사항은 다음과 같이 요약 할 수 있습니다.
모든 요소에서 xml : lang 속성 대신 lang 속성이 제거되었습니다 .
<a> 및 <map> 요소에서 id 속성 대신 name 속성이 제거되었습니다.
요소 의 루비 컬렉션이 추가되었습니다.
이 장에서는 XHTML 문서를 작성하는 동안 알아야 할 다양한 팁과 요령을 나열합니다. 이러한 팁과 요령은 효과적인 문서를 만드는 데 도움이 될 수 있습니다.
XHTML 문서 디자인을위한 팁
다음은 XHTML 문서를 디자인하기위한 몇 가지 기본 지침입니다.
청중에게 서비스를 제공하고 참여시키기위한 디자인
청중이 원하는 것을 만족시킬 생각이라면 그 목적에 부합하는 효과적이고 눈에 띄는 문서를 디자인해야합니다. 문서는 필요한 정보를 찾고 친숙한 환경을 제공하기 쉬워야합니다.
예를 들어, 학계 또는 의료 종사자는 긴 문장, 복잡한 다이어그램, 특정 용어 등이 포함 된 저널 형식의 문서에 익숙하지만 학교에 다니는 어린이가 액세스하는 문서는 간단하고 유익해야합니다.
문서 재사용
새 프로젝트를 넣을 때마다 처음부터 시작하는 대신 이전에 만든 성공한 문서를 재사용하십시오.
XHTML 문서 내부
다음은 XHTML 문서의 요소에 관한 몇 가지 팁입니다.
XML 선언
모든 XHTML 문서에서 XML 선언이 필요하지는 않지만 XHTML 문서 작성자는 모든 문서에서 XML 선언을 사용하는 것이 좋습니다. 문서의 문자 인코딩이 기본 UTF-8 또는 UTF-16이 아닌 경우 이러한 선언이 필요합니다.
빈 요소
빈 요소의 후행 / 및> 앞에 공백이 포함됩니다. 예 : <br />, <hr /> 및 <img src = "/ html / xhtml.gif"alt = "xhtml"/>.
포함 된 스타일 시트 및 스크립트
스타일 시트가 "<", "&", "]]>"또는 "—"를 사용하는 경우 외부 스타일 시트를 사용합니다.
스크립트에서 "<", "&"또는 "]]>"또는 "—"를 사용하는 경우 외부 스크립트를 사용하십시오.
속성 값 내의 줄 바꿈
속성 값 내에서 줄 바꿈 및 여러 공백 문자를 사용하지 마십시오. 이는 다른 브라우저에서 일관되지 않게 처리됩니다.
Isindex 요소
문서 헤드에 isindex 요소를 두 개 이상 포함하지 마십시오 . ISINDEX의 요소는 입력 요소에 찬성되지 않습니다.
LANG 및 XML : 랭 속성
요소의 언어를 지정하는 동안 lang 및 xml : lang 속성을 모두 사용하십시오 . xml : lang 속성 의 값 이 우선합니다.
요소 식별자
XHTML 1.0은 a, 애플릿, 양식, 프레임, iframe, img 및 맵 요소 의 이름 속성을 더 이상 사용하지 않습니다 . 후속 버전에서는 XHTML에서 제거됩니다. 따라서 요소 식별을 위해 id 요소를 사용하십시오 .
속성 값에 앰퍼샌드 사용
앰퍼샌드 문자 ( "&")는 엔티티 참조 &로 표시되어야합니다.
예
<!-- This is invalid in XHTML -->
http://my.site.dom/cgi-bin/myscript.pl?class=guest&name=user.
<!-- Correct XHTML way of writing this is as follows -->
http://my.site.dom/cgi-bin/myscript.pl?class=guest&name=user
HTML 및 XML의 공백 문자
HTML 문서에서 유효한 일부 문자는 XML 문서에서 불법입니다. 예를 들어, HTML에서 양식 공급 문자 (U + 000C)는 XML의 문자 정의로 인해 XHTML에서 공백으로 처리되며 이는 불법입니다.
명명 된 문자 참조 & Apos;
명명 된 문자 참조 '(아포스트로피, U + 0027)는 XML 1.0에서 도입되었지만 HTML에는 나타나지 않습니다. 따라서 웹 개발자는 & # 39; '대신 HTML 4 웹 브라우저에서 예상대로 작동합니다.
모든 XHTML 문서는 문서 유형 정의에 대해 유효성이 검사됩니다. XHTML 파일의 유효성을 제대로 확인하기 전에 올바른 DTD를 파일의 첫 번째 또는 두 번째 줄로 추가해야합니다.
XHTML 문서의 유효성을 검사 할 준비가되면 W3C Validator를 사용하여 문서의 유효성을 검사 할 수 있습니다. 이 도구는 매우 편리하며 문서의 문제를 해결하는 데 도움이됩니다. 이 도구는 검증을 수행하는 데 전문 지식이 필요하지 않습니다.
텍스트 상자의 다음 문은 세부 정보를 보여줍니다. 유효성을 검사 할 페이지의 전체 URL을 제공 한 다음Validate Page 단추.
아래 상자에 페이지 주소를 입력하십시오-
이 검사기는 특히 HTML, XHTML, SMIL, MathML 등에서 다양한 형식으로 웹 문서 의 마크 업 유효성 을 검사합니다 .
다른 유효성 검사를 수행하는 다른 도구가 있습니다.
RSS/Atom feeds Validator
CSS stylesheets Validator
Find Broken Links
Other validators and tools
XHTML과 관련된 모든 개념을 이해했다고 가정합니다. 따라서 HTML 문서를 올바른 형식의 XHTML 문서로 작성하고 더 깨끗한 웹 사이트 버전을 얻을 수 있어야합니다.
HTML을 XHTML로 변환
기존 HTML 웹 사이트를 XHTML 웹 사이트로 변환 할 수 있습니다.
몇 가지 중요한 단계를 살펴 보겠습니다. 기존 문서를 변환하려면 먼저 준수 할 DTD를 결정하고 문서 상단에 문서 유형 정의를 포함해야합니다.
다른 모든 필수 요소가 있는지 확인하십시오. 여기에는 XML 네임 스페이스를 나타내는 루트 요소 <html>, <head> 요소, <head> 요소에 포함 된 <title> 요소 및 <body> 요소가 포함됩니다.
모든 요소 키워드와 속성 이름을 소문자로 변환합니다.
모든 속성이 name = "value"형식인지 확인하십시오.
모든 컨테이너 요소에 닫는 태그가 있는지 확인하십시오.
모든 독립형 요소 안에 슬래시를 배치합니다. 예를 들어 모든 <br> 요소를 <br />로 다시 작성하십시오.
클라이언트 측 스크립트 코드와 스타일 시트 코드를 CDATA 섹션으로 지정합니다.
XHTML 향후 버전
여전히 XHTML이 개선되고 있으며 다음 버전 인 XHTML 1.1이 초안되었습니다. 이에 대해서는 XHTML 버전 1.1 장에서 자세히 논의했습니다.
XHTML 태그, 문자 및 엔티티
XHTML 태그, 문자 및 엔티티는 HTML과 동일하므로 이미 HTML을 알고 있다면 특히 XHTML의 경우 이러한 주제를 배우기 위해 추가 노력을 기울일 필요가 없습니다. XHTML에도 적용 할 수 있기 때문에 모든 HTML 항목을 XHTML 자습서와 함께 나열했습니다.
다음은 무엇입니까?
XHTML 및 HTML에 대한 다양한 리소스를 나열 했으므로 관심이 있고 시간이 있다면 이러한 리소스를 살펴보고 XHTML에 대한 이해를 높이는 것이 좋습니다. 그렇지 않으면이 튜토리얼은 XHTML을 사용하여 웹 페이지를 작성하는 데 충분한 지식을 제공했을 것입니다.
이 튜토리얼에 대한 귀하의 피드백은 [email protected]에서 환영합니다.