XML 개체 모델에서 공백 문자는 어떻게 처리됩니까?
경우에 따라 XML 개체 모델은 공백 문자가 포함된 TEXT 노드를 표시합니다. 공백 문자가 잘리면 약간의 혼란이 발생할 수 있습니다. 예를 들어 다음 XML 예는 다음과 같습니다.
]>
스미스
남자
다음 트리가 생성됩니다.
처리 지침: xml
문서 유형: 사람
요소: 사람
텍스트:
요소: 성
텍스트:
요소: 이름
텍스트:
"person" 요소의 콘텐츠 모델은 #PCDATA 키워드를 포함하므로 이름과 성은 공백 문자만 포함하는 TEXT 노드로 둘러싸여 있습니다. MIXED 콘텐츠 모델은 요소 사이에 텍스트가 존재할 수 있음을 지정합니다. 따라서 다음도 옳습니다.
내 성은 Smith이고 이름은 Smith입니다.
남자
결과는 다음과 유사한 트리입니다.
요소: 사람
텍스트: 내 성은 다음과 같습니다.
요소: 성
텍스트: 내 이름은
요소: 이름
텍스트:
"is"라는 단어 뒤와 앞의 공백 문자와 "and"라는 단어 뒤와 앞의 공백 문자가 없으면 문장을 이해할 수 없습니다. 따라서 MIXED 콘텐츠 모델의 경우 텍스트 조합, 공백 문자 및 요소가 모두 관련됩니다. 이는 MIXED가 아닌 콘텐츠 모델의 경우에는 해당되지 않습니다.
공백 전용 TEXT 노드를 사라지게 하려면 "person" 요소 선언에서 #PCDATA 키워드를 제거하십시오.
결과는 다음과 같은 명확한 트리입니다.
처리 지침: xml
문서 유형: 사람
요소: 사람
요소: 성
ELEMENT: 이름
XML 선언의 기능은 무엇입니까?
XML 선언은 XML 문서의 맨 위에 나열되어야 하며
다음 항목을 지정합니다
.문서는 XML 문서입니다. MIME 탐지기는 이를 사용하여 MIME 유형이 없거나 지정되지 않은 경우 파일 유형이 text/xml인지 여부를 탐지할 수 있습니다.
문서는 XML 1.0 사양을 준수합니다. 이는 앞으로 다른 버전의 XML이 있을 때 중요해질 것입니다.
문서 문자 인코딩. 인코딩 속성은 선택 사항이며 기본값은 UTF-8입니다.
참고: XML 선언은 XML 문서의 첫 번째 줄에 있어야 하므로 다음 XML 파일은
다음 구문 분석 오류를 생성합니다.
잘못된 xml 선언.
라인 0000002:
위치 0000007: ------^
참고: XML 선언은 선택 사항입니다. 상단에 주석이나 처리 지침을 지정해야 하는 경우 XML 선언을 넣지 마세요. 그러나 기본 인코딩은 UTF-8입니다.
XML 문서를 읽을 수 있는 형식으로 인쇄하려면 어떻게 해야 합니까?
XML 파일을 생성하기 위해 DOM을 사용하여 처음부터 문서를 구성할 때 모든 항목은 공백 없이 한 줄에 표시됩니다. 이것이 기본 동작입니다.
읽을 수 있는 형식으로 XML 문서를 표시하고 인쇄하기 위해 Internet Explorer 5에서 기본 XSL 스타일시트를 구성합니다. 예를 들어 IE5가 이미 설치되어 있는 경우 nospace.xml 파일을 살펴보세요. 브라우저에 다음 트리가 나타나야 합니다.
-
-
XYZ
12.56
XML에 공백 문자가 삽입되지 않습니다.
읽을 수 있는 XML을 인쇄하는 것은 매우 흥미롭습니다. 특히 다양한 유형의 콘텐츠 모델을 정의하는 DTD가 있는 경우에는 더욱 그렇습니다. 예를 들어 혼합 콘텐츠 모델(#PCDATA)에서는 공백을 삽입하면 콘텐츠의 의미가 변경될 수 있으므로 공백을 삽입할 수 없습니다. 예를 들어 다음 XML을 고려해 보세요
.
이것은 다음과 같이 출력되지 않는 것이 가장 좋습니다:
E
코끼리
단어 경계가 더 이상 정확하지 않기 때문입니다.
이 모든 것이 자동화된 인쇄에 문제를 야기합니다. 읽을 수 있는 XML을 인쇄할 필요가 없다면 DOM을 사용하여 적절한 위치에 공백 문자를 텍스트 노드로 삽입할 수 있습니다.
DTD에서 네임스페이스를 어떻게 사용합니까? DTD에서 네임스페이스를 사용하려면 이를 사용하는 요소의 ATTLIST 선언에서 다음과 같이 선언하십시오.
네임스페이스 유형은 #FIXED여야 합니다. 속성 네임스페이스도 마찬가지입니다.
네임스페이스와 XML 스키마 DTD와 XML 스키마는 혼합될 수 없습니다. 예를 들어, 다음
xmlns:x CDATA #FIXED "x-스키마:myschema.xml"
myschema.xml에 정의된 스키마 정의가 사용되지 않습니다. DTD와 XML 스키마의 사용은 상호 배타적입니다.
Visual Basic에서 XMLDSO를 사용하는 방법은 무엇입니까?
다음 XML을 예로 사용하세요.
마크 핸슨
206 765 4583
제인 스미스
425 808 1111
다음과 같이 ADO 레코드 세트에 바인딩할 수 있습니다.
새 VB 6.0 프로젝트를 만듭니다.
Microsoft ActiveX Data Objects 2.1 이상, Microsoft Data Adapter Library 및 Microsoft XML 버전 2.0에 대한 참조를 추가합니다.
다음 코드를 사용하여 XML 데이터를 XML DSO 컨트롤에 로드합니다.
새로운 XMLDSOControl로 dso를 흐리게 합니다.
IXMLDOMDocument로 희미한 문서
문서 설정 = dso.XMLDocument
doc.Load("d:test.xml")는
다음 코드를 사용하여 DataAdapter를 사용하여 DSO를 새 레코드 세트 개체에 매핑합니다.
새로운 DataAdapter로 Dim da
da.Object = dso로 설정
새로운 ADODB.Recordset으로 Dim rs
rs.DataSource = da로 설정
데이터에 액세스:
MsgBox rs.Fields("name").Value의
결과는 "Mark Hanson" 문자열입니다
.
Java에서 XML DOM을 사용하는 방법은 무엇입니까?
IE5 버전의 MSXML.DLL이 설치되어 있어야 합니다. Visual J++ 6.0에서는 프로젝트 메뉴에서 COM 래퍼 추가를 선택한 다음 COM 개체 목록에서 "Microsoft XML 1.0"을 선택합니다. 그러면 필수 Java 래퍼가 "msxml"이라는 새 패키지로 구성됩니다. 사전 구축된 Java 래퍼도 다운로드할 수 있습니다. 클래스는 다음과 같이 사용할 수 있습니다.
com.ms.com.* 가져오기;
msxml.* 가져오기;
공개 수업 Class1
{
공개 정적 무효 메인(String[] args)
{
DOMDocument doc = 새로운 DOMDocument();
doc.load(new Variant(" file://d:/samples/ot.xml "));
System.out.println("로드됨 " + doc.getDocumentElement().getNodeName());
}
}
코드 예제에서는 태양 종교 예제에서 3.8MB 테스트 파일 "ot.xml"을 로드합니다. Variant 클래스는 Win32 VARIANT 기본 유형을 래핑합니다.
실제로 노드를 검색할 때마다 새로운 래퍼를 가져오기 때문에 노드에 대한 포인터 비교를 사용할 수 없습니다. 따라서 아래 코드를 사용하지 마십시오.
IXMLDOMNode root1 = doc.getDocumentElement();
IXMLDOMNode root2 = doc.getDocumentElement();
if (루트1 == 루트2)...
대신 다음 코드를 사용하세요.
if (ComLib.isEqualUnknown(root1, root2)) ....
.class 래퍼의 총 크기는 약 160KB입니다. 그러나 W3C 사양을 완전히 준수하려면 IXMLDOM* 래퍼만 사용해야 합니다. 다음 클래스는 이전 IE 4.0 XML 인터페이스이며 msxml 폴더에서 제거할 수 있습니다.
IXML속성*,
IXMLDocument*, XMLDocument*
IXMLElement*,
IXML오류*,
IXMLElementCollection*,
태그XMLEMEM_TYPE*
_xml_오류*
이렇게 하면 크기가 147KB로 줄어듭니다. 다음 항목도 삭제할 수 있습니다.
DOMFreeThreaded문서
Java 애플리케이션의 여러 스레드에서 XML 문서에 액세스합니다.
XMLHttp요청
XML DAV HTTP 확장을 사용하여 서버와 통신합니다.
IXTL런타임
XSL 스타일시트 스크립트 개체를 정의합니다.
XMLDSO컨트롤
HTML 페이지의 XML 데이터에 바인딩합니다.
XMLDOMDocument이벤트
분석 중에 콜백을 반환합니다.
이렇게 하면 크기가 116KB로 줄어듭니다. DOM을 더 작게 만들려면 DOM 자체에 두 개의 레이어가 있다는 사실을 고려하세요. 핵심 레이어는 다음으로 구성됩니다.
DOM문서, IXMLDOM문서
IXMLDOM노드*
IXMLDOMNodeList*
IXMLDOMNamedNodeMap*
IXMLDOMDocumentFragment*
IXMLDOM구현
IXMLDOMParseError
사용자가 보관해야 할 DTD 정보는 다음과 같습니다.
IXMLDOM문서 유형
IXMLDOM엔티티
IXMLDOM표기법
XML 문서의 모든 노드 유형은 전체 기능을 제공하는 IXMLDOMNodes이지만 각 노드 유형에 대해 더 높은 수준의 래퍼가 있습니다. 따라서 DOMDocument 래퍼를 수정하고 IXMLDOMNode를 사용하도록 이러한 특정 유형을 변경하면 다음 인터페이스가 모두 제거될 수 있습니다.
IXMLDOM속성
IXMLDOMCDATA섹션
IXMLDOM캐릭터데이터
IXMLDOM댓글
IXMLDOME요소
IXMLDOM처리 명령
IXMLDOMEntity참조
IXMLDOM텍스트
이를 제거하면 크기가 61KB로 줄어듭니다. 그러나 IXMLDOMElement의 경우 getAttribute 및 setAttribute 메소드가 모두 유용합니다. 그렇지 않으면 다음을 사용해야 합니다.
IXMLDOMNode.getAttributes().setNamedItem(...)