2009-06-03 9 views
0

XSLファイルを使用してBDCリストWebpartのデータベース列名を変更したいと思います。XSLTを使用してSharepoint BDC webpartの列ヘッダーを編集

私のSQLクエリは"Select BATCH_ID..."です。XSLを使用して、その列名を"BATCH_ID"から"ID"に変更します。 $ColName_0の値が'BATCH_ID'に設定されていることも知りたいですか?

dvt.headerfieldテンプレート内では、ソートメニューが追加されています。ただし、テンプレートが呼び出される前に$ColName_0が入力されます。 XSLTコードは以下の通りです:

<xsl:stylesheet 
    version="1.0" 
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
    xmlns:ddwrt="http://schemas.microsoft.com/WebParts/v2/DataView/runtime" 
    xmlns:asp="http://schemas.microsoft.com/ASPNET/20" 
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" 
    xmlns:SharePoint="Microsoft.Sharepoint.WebControls" 
    exclude-result-prefixes="xsl msxsl ddwrt" 
> 
    <xsl:output method="xml" indent="yes"/> 
    <xsl:param name="dvt_partguid" /> 
    <xsl:param name="ColName_0"></xsl:param> 

    <xsl:template name="dvt.headerfield"> 
    <xsl:param name="fieldname" /> 
    <xsl:param name="fieldtitle" /> 
    <xsl:param name="displayname" /> 
    <xsl:param name="fieldtype">0</xsl:param> 

    <table CtxNum="1" cellspacing="0" class="ms-unselectedtitle" onmouseover="OnMouseOverAdHocFilter(this, '{concat($displayname,$fieldname, $fieldtype, $dvt_partguid)}')"> 
     <tr> 
     <td width="100%" class="ms-vb" nowrap=""> 
      <a> 
      <xsl:attribute name="href">javascript: <xsl:value-of select="ddwrt:GenFireServerEvent(('dvt_sortfield;dvt_sortdir'))" />;</xsl:attribute> 
      <xsl:value-of select="$fieldtitle"/> 
      </a>     
     </td> 
     <td> 
      <img src="/_layouts/images/blank.gif" width="13" style="visibility: hidden" alt="" /> 
     </td> 
     </tr> 
    </table> 
    </xsl:template> 

    <xsl:template match="/"> 
    <xsl:call-template name="dvt_1" /> 
    </xsl:template> 

    <xsl:template name="dvt_1"> 
    <xsl:variable name="dvt_StyleName">Table</xsl:variable> 

    <table id="BdwpRows" border="0" width="100%" cellpadding="2" cellspacing="0"> 
     <tr valign="top"> 
     <th class="ms-vh" width="1" /> 
     <th class="ms-vh" align="left"> 
      <xsl:call-template name="dvt.headerfield" ddwrt:atomic="1"> 
      <xsl:with-param name="fieldname">@BATCH_ID</xsl:with-param> 
      <xsl:with-param name="fieldtitle"> 
       <xsl:value-of select="$ColName_0" /> 
      </xsl:with-param> 
      <xsl:with-param name="displayname"> 
       <xsl:value-of select="$ColName_0" /> 
      </xsl:with-param> 
      <xsl:with-param name="fieldtype">text</xsl:with-param> 
      </xsl:call-template> 
     </th> 
     </tr>   
    </table> 
    </xsl:template> 
</xsl:stylesheet> 
+0

あなたが投稿することができますxsltが動作するためのサンプルxml? –

答えて

0

ないことが最善の方法だが、ここで私はそれをやった方法です確認してください。

変更:

<xsl:with-param name="fieldname">@BATCH_ID</xsl:with-param> 
    <xsl:with-param name="fieldtitle"> 
     <xsl:value-of select="$ColName_0" /> 
    </xsl:with-param> 
    <xsl:with-param name="displayname"> 
     <xsl:value-of select="$ColName_0" /> 
    </xsl:with-param> 
<xsl:with-param name="fieldtype">text</xsl:with-param> 

た:

<xsl:with-param name="fieldname">@BATCH_ID</xsl:with-param> 
    <xsl:with-param name="fieldtitle"> 
     ID 
    </xsl:with-param> 
    <xsl:with-param name="displayname"> 
     <xsl:value-of select="$ColName_0" /> 
    </xsl:with-param> 
<xsl:with-param name="fieldtype">text</xsl:with-param> 
関連する問題