2009-06-03 14 views
0

Ich möchte die Datenbankspaltennamen eines BDC-Listen-Webparts mithilfe einer XSL-Datei ändern.Bearbeiten der Spaltenüberschrift des Sharepoint BDC-Webparts mit XSLT

Meine SQL-Abfrage ist "Select BATCH_ID...", ich möchte diesen Spaltennamen "BATCH_ID" zu "ID" mit XSL ändern. Ich möchte auch wissen, wie $ColName_0 mit dem Wert 'BATCH_ID' aufgefüllt wird?

Innerhalb der dvt.headerfield Vorlage ist Sortieren und Hinzufügen von Sortiermenü. Aber $ColName_0 ist ausgefüllt, bevor diese Vorlage aufgerufen wird. XSLT-Code folgt:

<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

Können Sie nach einige Beispiel-XML für die Xslt zu arbeiten? –

Antwort

0

nicht sicher, dass es der beste Weg, aber hier ist, wie ich es tat:

Wechsel:

<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> 

An:

<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> 
Verwandte Themen