修改WSS的控件的RenderingTemplate,可以灵活的控制表单页面的显示。
以前写过几篇相关的文章:
TemplateBasedControl从这个类继承下来,控件就具有了加载模板的功能。
看一下这个类的方法:

public class TemplateBasedControl : SPControl, INamingContainer
{
    // Methods
    public TemplateBasedControl();
    [SharePointPermission(SecurityAction.Demand, ObjectModel
=true)]
    
protected override void CreateChildControls();
    
public static TemplateBasedControl GetParentTemplateBasedControl(Control control);
    [SharePointPermission(SecurityAction.Demand, ObjectModel
=true)]
    
protected override void OnLoad(EventArgs e);
    [SharePointPermission(SecurityAction.Demand, ObjectModel
=true)]
    
protected override void Render(HtmlTextWriter output);

    
// Properties
    [TemplateContainer(typeof(TemplateContainer))]
    
public ITemplate AlternateTemplate { getset; }
    
public string AlternateTemplateName { getset; }
    
public override ControlCollection Controls { [SharePointPermission(SecurityAction.Demand, ObjectModel=true)] get; }
    
protected virtual ITemplate ControlTemplate { get; }
    [TemplateContainer(
typeof(TemplateContainer)), PersistenceMode(PersistenceMode.InnerProperty)]
    
public ITemplate CustomAlternateTemplate { getset; }
    [TemplateContainer(
typeof(TemplateBasedControl)), PersistenceMode(PersistenceMode.InnerProperty)]
    
public ITemplate CustomTemplate { getset; }
    
protected virtual string DefaultAlternateTemplateName { get; }
    
protected virtual string DefaultTemplateName { get; }
    
public SPContext RenderContext { getset; }
    [TemplateContainer(
typeof(TemplateBasedControl))]
    
public ITemplate Template { getset; }
    
public virtual TemplateContainer TemplateContainer { get; }
    
public string TemplateName { getset; }
    
protected TemplateOverride TemplateOverride { getset; }
    
public virtual SPWeb Web { get; }
}


注意两个重要的属性:DefaultTemplateName 和TemplateName,这两个属性配置了控件的默认模板和自定义模板。若没有指定TemplateName,则TemplateName跟DefaultTemplateName一致,见如下代码:

再议WSS RenderingTemplatepublic string TemplateName


在系统的默认模板文件(Defaulttemplate.ascx)中,很多控件都是从TemplateBasedControl继承的,应此他们具有加载模板的能力,很多情况下,一个模板控件还会加载其他的模板,模板中还会有模板控件,于是就形成了一个模板套模板的结构。
系统的模板控件在设计的时候,一般只会指定DefaultTemplateName,这样,我们就可以通过修改TemplateName来替换默认模板。
ListFieldIterator控件,她只是重载了DefaultTemplateName属性:

再议WSS RenderingTemplateprotected override string DefaultTemplateName

表单页面模板一般为LitstForm ,如下:
>

LitstForm 模板中嵌入了ListFieldIterator控件,这个控件遍历生成所有的字段控件,ListFieldIterator控件的默认模板是ListFieldIterator,如下:
再议WSS RenderingTemplate<SharePoint:RenderingTemplate ID="ListFieldIterator" runat="server">
再议WSS RenderingTemplate    
<Template>
再议WSS RenderingTemplate        
<TR><SharePoint:CompositeField runat="server"/></TR>
再议WSS RenderingTemplate    
</Template>
再议WSS RenderingTemplate
</SharePoint:RenderingTemplate>
这个模板中又嵌入了CompositeField控件,CompositeField控件的默认模板是CompositeField,内容如下:再议WSS RenderingTemplate 
再议WSS RenderingTemplate

 

再议WSS RenderingTemplate<SharePoint:RenderingTemplate ID="CompositeField" runat="server">
再议WSS RenderingTemplate    
<Template>
再议WSS RenderingTemplate        
<TD nowrap="true" valign="top" width="190px" class="ms-formlabel"><H3 class="ms-standardheader"><SharePoint:FieldLabel runat="server"/></H3></TD>
再议WSS RenderingTemplate        
<TD valign="top" class="ms-formbody" width="400px">
再议WSS RenderingTemplate        
<!-- FieldName="<SharePoint:FieldProperty PropertyName="Title" runat="server"/>"
再议WSS RenderingTemplate             FieldInternalName="<SharePoint:FieldProperty PropertyName="InternalName" runat="server"/>"
再议WSS RenderingTemplate             FieldType="SPField<SharePoint:FieldProperty PropertyName="Type" runat="server"/>"
再议WSS RenderingTemplate          
-->
再议WSS RenderingTemplate            
<SharePoint:FormField runat="server"/>
再议WSS RenderingTemplate            
<SharePoint:FieldDescription runat="server"/>
再议WSS RenderingTemplate            
<SharePoint:AppendOnlyHistory runat="server"/>
再议WSS RenderingTemplate        
</TD>
再议WSS RenderingTemplate    
</Template>
再议WSS RenderingTemplate
</SharePoint:RenderingTemplate>


如果要全面定制一个表单页面,需要修改以上的所有模板。
下面,演示一下如何将一个表单定制成如下样式:
再议WSS RenderingTemplate
新建一个模板文件:
TestTemplates.ascx,敲入一下代码:

再议WSS RenderingTemplate<%@ Control Language="C#"   AutoEventWireup="false" %>
再议WSS RenderingTemplate
<%@Assembly Name="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
再议WSS RenderingTemplate
<%@Register TagPrefix="SharePoint" Assembly="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" namespace="Microsoft.SharePoint.WebControls"%>
再议WSS RenderingTemplate
<%@Register TagPrefix="SPHttpUtility" Assembly="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" namespace="Microsoft.SharePoint.Utilities"%>
再议WSS RenderingTemplate
<%@ Register TagPrefix="wssuc" TagName="ToolBar" src="~/_controltemplates/ToolBar.ascx" %>
再议WSS RenderingTemplate
<%@ Register TagPrefix="wssuc" TagName="ToolBarButton" src="~/_controltemplates/ToolBarButton.ascx" %>
再议WSS RenderingTemplate
<SharePoint:RenderingTemplate ID="ListForm" runat="server">
再议WSS RenderingTemplate    
<Template>
再议WSS RenderingTemplate        
<SPAN id='part1'>
再议WSS RenderingTemplate            
<SharePoint:InformationBar runat="server"/>
再议WSS RenderingTemplate            
再议WSS RenderingTemplate            
<SharePoint:FormToolBar runat="server"/>
再议WSS RenderingTemplate
再议WSS RenderingTemplate
<div>
再议WSS RenderingTemplate
<SharePoint:ListFieldIterator runat="server" TemplateName="ListFieldIterator2" />
再议WSS RenderingTemplate
</div>
再议WSS RenderingTemplate
再议WSS RenderingTemplate            
<TABLE class="ms-formtable" style="margin-top: 8px;" border=0 cellpadding=0 cellspacing=0 width=100%>
再议WSS RenderingTemplate
再议WSS RenderingTemplate            
<SharePoint:ChangeContentType runat="server"/>
再议WSS RenderingTemplate            
<SharePoint:FolderFormFields runat="server"/>
再议WSS RenderingTemplate            
再议WSS RenderingTemplate            
<SharePoint:ApprovalStatus runat="server"/>
再议WSS RenderingTemplate            
<SharePoint:FormComponent TemplateName="AttachmentRows" runat="server"/>
再议WSS RenderingTemplate            
</TABLE>再议WSS RenderingTemplate
再议WSS RenderingTemplate            
<table cellpadding=0 cellspacing=0 width=100%><tr><td class="ms-formline"><IMG SRC="/_layouts/images/blank.gif" width=1 height=1 alt=""></td></tr></table>
再议WSS RenderingTemplate            
<TABLE cellpadding=0 cellspacing=0 width=100% style="padding-top: 7px"><tr><td width=100%>
再议WSS RenderingTemplate            
<SharePoint:ItemHiddenVersion runat="server"/>
再议WSS RenderingTemplate            
<SharePoint:ParentInformationField runat="server"/>
再议WSS RenderingTemplate            
<SharePoint:InitContentType runat="server"/>
再议WSS RenderingTemplate            
<wssuc:ToolBar CssClass="ms-formtoolbar" id="toolBarTbl" RightButtonSeparator="&nbsp;" runat="server">
再议WSS RenderingTemplate                    
<Template_Buttons>
再议WSS RenderingTemplate                        
<SharePoint:CreatedModifiedInfo runat="server"/>
再议WSS RenderingTemplate                    
</Template_Buttons>
再议WSS RenderingTemplate                    
<Template_RightButtons>
再议WSS RenderingTemplate                        
<SharePoint:SaveButton runat="server"/>
再议WSS RenderingTemplate                        
<SharePoint:GoBackButton runat="server"/>
再议WSS RenderingTemplate                    
</Template_RightButtons>
再议WSS RenderingTemplate            
</wssuc:ToolBar>
再议WSS RenderingTemplate            
</td></tr></TABLE>
再议WSS RenderingTemplate        
</SPAN>
再议WSS RenderingTemplate        
<SharePoint:AttachmentUpload runat="server"/>
再议WSS RenderingTemplate    
</Template>
再议WSS RenderingTemplate
</SharePoint:RenderingTemplate>
再议WSS RenderingTemplate
再议WSS RenderingTemplate
<SharePoint:RenderingTemplate ID="ListFieldIterator2" runat="server">
再议WSS RenderingTemplate    
<Template>
再议WSS RenderingTemplate        
<SharePoint:CompositeField runat="server" TemplateName="CompositeField2"/>
再议WSS RenderingTemplate    
</Template>
再议WSS RenderingTemplate
</SharePoint:RenderingTemplate>
再议WSS RenderingTemplate
再议WSS RenderingTemplate
<SharePoint:RenderingTemplate ID="CompositeField2" runat="server">
再议WSS RenderingTemplate    
<Template>
再议WSS RenderingTemplate
再议WSS RenderingTemplate        
<H3 class="ms-standardheader"><SharePoint:FieldLabel runat="server"/></H3>
再议WSS RenderingTemplate         
<br/>
再议WSS RenderingTemplate        
<!-- FieldName="<SharePoint:FieldProperty PropertyName="Title" runat="server"/>"
再议WSS RenderingTemplate             FieldInternalName="<SharePoint:FieldProperty PropertyName="InternalName" runat="server"/>"
再议WSS RenderingTemplate             FieldType="SPField<SharePoint:FieldProperty PropertyName="Type" runat="server"/>"
再议WSS RenderingTemplate          
-->
再议WSS RenderingTemplate        
<SharePoint:FormField runat="server"/>
再议WSS RenderingTemplate        
<SharePoint:FieldDescription runat="server"/>
再议WSS RenderingTemplate        
<SharePoint:AppendOnlyHistory runat="server"/>
再议WSS RenderingTemplate         
<br/>
再议WSS RenderingTemplate    
</Template>
再议WSS RenderingTemplate
</SharePoint:RenderingTemplate>
再议WSS RenderingTemplate


以上代码修改了ListFieldIterator,CompositeField两个控件的默认模板。

注意:这个修改几乎对所有的列表表单起作用,因为直接覆盖了ID为ListForm的模板。
若只需要对某个表单起作用,需要将第一个模板的ID改掉,不能跟系统已有模本ID重复,然后按照本文开头罗列的几篇文章中的方法,或者用SPD修改ListFormWebPart的模板名,或者用SmartForm加载新的模板。

文件保存后,重启IIS即可看到效果。

相关文章: