다음을 통해 공유


연습: XSLT 스타일시트 디버그

이 연습 단계에서는 XSLT 디버거를 사용하는 방법을 보여 줍니다. 이 단계에는 변수 보기, 중단점 설정 및 단계별로 코드 실행이 포함됩니다. 디버거를 사용하면 한 번에 한 줄씩 코드를 실행할 수 있습니다.

이 연습을 준비하려면 먼저 두 개의 샘플 파일을 로컬 컴퓨터에 복사합니다. 하나는 스타일시트이고 하나는 스타일시트에 대한 입력으로 사용할 XML 파일입니다. 이 연습에서는 사용하는 스타일시트가 비용이 평균 book 가격 미만인 모든 book을 찾습니다.

참고 항목

XSLT 디버거는 Visual Studio의 Professional 및 Enterprise Edition에서만 사용할 수 있습니다.

디버그 시작

  1. 파일 메뉴에서 열기>파일을 선택합니다.

  2. below-average.xsl 파일을 찾고 열기를 선택합니다.

    XML 편집기에서 스타일시트를 엽니다.

  3. 문서 속성 창의 입력 필드에서 찾아보기 단추(...)를 클릭합니다 (속성 창이 표시되지 않으면 편집기에서 열려 있는 파일의 아무 곳이나 마우스 오른쪽 단추로 클릭하고 속성 선택).

  4. books.xml 파일을 찾은 다음 열기를 선택합니다.

    그러면 XSLT 변형에 사용되는 소스 문서 파일이 설정됩니다.

  5. below-average.xsl의 줄 12에서 중단점을 설정합니다. 다음의 여러 방법 중 하나를 사용하여 이 작업을 수행할 수 있습니다.

    • 줄 12에서 편집기의 여백을 클릭합니다.

    • 줄 12의 아무 곳이나 클릭한 다음 F9를 누릅니다.

    • xsl:if 시작 태그를 마우스 오른쪽 단추로 클릭한 다음 중단점>중단점 삽입을 선택합니다.

      Insert breakpoint in XSL file in Visual Studio

  6. 메뉴 모음에서 XML>XSLT 디버깅 시작을 선택하거나 Alt+F5를 누릅니다.

    디버깅 프로세스가 시작됩니다.

    편집기에서 디버거는 스타일시트의 xsl:if 요소에 배치됩니다. 편집기에서 below-average.xml이라는 다른 파일이 열립니다. 이 파일은 입력 파일 books.xml의 각 노드가 처리될 때 채워질 출력 파일입니다.

    자동, 지역조사식 1 창이 Visual Studio 창의 맨 아래에 표시됩니다. 지역 창에 모든 지역 변수 및 현재 값이 표시됩니다. 여기에는 스타일시트에 정의된 변수가 포함되며 디버거에서 현재 컨텍스트에 있는 노드를 추적하는 데 사용하는 변수도 포함됩니다.

조사식 창

입력 파일이 처리될 때 해당 값을 검사할 수 있도록 조사식 1 창에 두 개의 변수를 추가합니다 (보려고 하는 변수가 이미 있는 경우 지역 창을 사용하여 값을 검사할 수도 있음).

  1. 디버그 메뉴에서 Windows>조사식>조사식 1을 선택합니다.

    조사식 1 창이 표시됩니다.

  2. 이름 필드에 $bookAverage를 입력한 다음 Enter 키를 누릅니다.

    $bookAverage 변수의 값은 필드에 표시됩니다.

  3. 다음 줄에서 이름 필드에 self::node()를 입력한 다음 Enter 키를 누릅니다.

    self::node()는 현재 컨텍스트 노드로 계산되는 XPath 식입니다. self::node() XPath 식의 값은 첫 번째 book 노드입니다. 이 값은 변환을 진행하면서 변경됩니다.

  4. self::node() 노드를 확장한 다음 값이 price인 노드를 확장합니다.

    Watch window during XSLT debugging in Visual Studio

    현재 book 노드의 book 가격 값을 확인하고 $bookAverage 값과 비교할 수 있습니다. book 가격이 평균 미만이기 때문에 디버깅 프로세스를 계속할 때 xsl:if 조건이 성공해야 합니다.

단계별로 코드 실행

  1. F5를 눌러 계속합니다.

    첫 번째 book 노드가 xsl:if 조건을 만족하기 때문에 book 노드가 below-average.xml 출력 파일에 추가됩니다. 디버거는 스타일시트의 xsl:if 요소에 다시 배치될 때까지 계속 실행됩니다. 이제 디버거가 books.xml 파일의 두 번째 book 노드에 배치됩니다.

    조사식 1 창에서 self::node() 값이 두 번째 book 노드로 변경됩니다. 가격 요소 값을 검사하여 가격이 평균을 초과하는 것을 확인할 수 있으므로 xsl:if 조건은 실패해야 합니다.

  2. F5를 눌러 계속합니다.

    두 번째 book 노드는 xsl:if 조건을 충족하지 않으므로 이 below-average.xml 출력 파일에 추가되지 않습니다. 디버거는 스타일시트의 xsl:if 요소에 다시 배치될 때까지 계속 실행됩니다. 이제 디버거가 books.xml 파일의 세 번째 book 노드에 배치됩니다.

    조사식 1 창에서 self::node() 값이 세 번째 book 노드로 변경됩니다. price 요소의 값을 확인하면 가격이 평균보다 낮음을 알 수 있습니다. xsl:if 조건이 성공해야 합니다.

  3. F5를 눌러 계속합니다.

    xsl:if 조건을 만족했기 때문에 세 번째 book이 below-average.xml 출력 파일에 추가됩니다. XML 문서에 있는 모든 book이 처리되었으므로 디버거가 중지됩니다.

샘플 파일

다음 두 파일은 연습에 사용됩니다.

below-average.xsl

<?xml version='1.0'?>
<xsl:stylesheet version="1.0"
      xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="xml" encoding="utf-8"/>
  <xsl:template match="/">
    <xsl:variable name="bookCount" select="count(/bookstore/book)"/>
    <xsl:variable name="bookTotal" select="sum(/bookstore/book/price)"/>
    <xsl:variable name="bookAverage" select="$bookTotal div $bookCount"/>
    <books>
      <!--Books That Cost Below Average-->
      <xsl:for-each select="/bookstore/book">
        <xsl:if test="price &lt; $bookAverage">
          <xsl:copy-of select="."/>
        </xsl:if>
      </xsl:for-each>
    </books>
  </xsl:template>
</xsl:stylesheet>

books.xml

<?xml version='1.0'?>
<!-- This file represents a fragment of a book store inventory database -->
<bookstore>
  <book genre="autobiography" publicationdate="1981" ISBN="1-861003-11-0">
    <title>The Autobiography of Benjamin Franklin</title>
    <author>
      <first-name>Benjamin</first-name>
      <last-name>Franklin</last-name>
    </author>
    <price>8.99</price>
  </book>
  <book genre="novel" publicationdate="1967" ISBN="0-201-63361-2">
    <title>The Confidence Man</title>
    <author>
      <first-name>Herman</first-name>
      <last-name>Melville</last-name>
    </author>
    <price>11.99</price>
  </book>
  <book genre="philosophy" publicationdate="1991" ISBN="1-861001-57-6">
    <title>The Gorgias</title>
    <author>
      <name>Plato</name>
    </author>
    <price>9.99</price>
  </book>
</bookstore>