2

XSLT変換を実行して、XMLをHTMLテーブルに変換します。表形式のデータなので、divを使用していません。;)

とにかく、コレクションの1つのサイズに対して、XSLTの一部を繰り返す必要があります。これがコードの抜粋です...

Dim styleSheet = <?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  xmlns:msxsl="urn:schemas-microsoft-com:xslt" 
  xmlns:rh="ReportHub"
  exclude-result-prefixes="msxsl"
>
  <xsl:output method="html" indent="yes" />
  <xsl:template match="rh:Report/rh:Tablix1/rh:Details_Collection">
    <xsl:variable name="alternating-row" select="position() mod 2" />
    <table class=<%= dataFormatter.formattingTableClass %>>
      <xsl:choose>
        <xsl:when test="count(rh:Details)=0">
          <tr>
            <td>There are no items listed for this client</td>
          </tr>
        </xsl:when>
        <xsl:otherwise>
          <xsl:for-each select="rh:Details">
            <tr class=<%= dataFormatter.formattingTRClass %>>
              <xsl:variable name="mainrow-position" select="position()" />
              <xsl:for-each select="@*">
                <%= From x In dataFormatter.dataColumnSettings Select 
                  <xsl:if test="name() != 'colName'">
                    <xsl:choose>
                      <xsl:when test="$mainrow-position=1">
                        <th>
                          <xsl:value-of select="name()"/>
                        </th>
                      </xsl:when>
                      <xsl:otherwise>
                        <td>
                          <xsl:value-of select="."/>
                        </td>
                      </xsl:otherwise>
                    </xsl:choose>
                  </xsl:if> 
                %>
              </xsl:for-each>
            </tr>
          </xsl:for-each>
        </xsl:otherwise>
      </xsl:choose>
    </table>
  </xsl:template>
</xsl:stylesheet>

問題は、LINQクエリ内のXMLがxsl名前空間を参照しているため、次のようになることです。

エラー9XML名前空間プレフィックス'xsl'が定義されていません。

誰かが賢いアイデアを思いついた?

  • LINQクエリ内のXMLの内部動作は完了していないため、どのように見えるかについて心配する必要はありません。
4

3 に答える 3

5

これが可能であることに少し驚いていましたが、これはVB.NETでのみ機能し、C#では機能しないことに気付きました。:-)とにかく、私はこれについてもっと学ぶためにMSDNを調べました、そしてそれは少し野蛮な推測です、しかし私はあなたがそれらの名前空間を追加するために別のImportsステートメントを使う必要があると思います。何かのようなもの:

Imports <xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
Imports <xmlns:msxsl="urn:schemas-microsoft-com:xslt">
Imports <xmlns:rh="ReportHub">

しかし、それは少し知識に基づいた推測です。あなたは賢いアイデアを求めました、これは私のものです。

于 2009-10-07T08:57:00.780 に答える
3

Importsステートメントを使用する必要があると思います。このようなもの:

Imports <xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
于 2009-10-07T08:57:40.077 に答える
1

これは、XLINQを含むすべてのXMLクエリテクノロジの標準的な動作です。ドキュメント内で宣言する名前空間は、クエリAPIで使用される名前空間に影響を与えません。認識させたい名前空間とは別に、クエリAPIに常に通知する必要があります。VB.NETインラインXMLの場合は、Importsステートメントを使用します。C#では、代わりにオブジェクトをインスタンス化します。これは、VB.NETの特殊な構文が、さまざまなコンストラクターXNamespaceに対する単なる構文上の糖衣であるためです。XObject

IIRCの背後にある理由は、ドキュメントが自分で作成されていない可能性があるため、ドキュメントの作成者が使用することを選択した名前空間プレフィックスを事前に予測する方法がないためです。安全な方法は、クエリAPIにクエリに使用する名前空間プレフィックスを指定することだけです。

于 2009-10-07T09:12:55.660 に答える