色婆ijqwj 发表于 2015-9-28 09:23:53

定制SharePoint表单

  开发SharePoint的时候遇到的很大一个问题就是:所有List Item的显示出来都一个样子的。这么样遇到表单复杂或者需要表单动作情况的时候就不适用了。在SharePoint 2007下能想到的最方便的方法就是用InfoPath集成的方式。InfoPath能够制作各种形式的form,这些form能够通过form service直接展现在web pages上,而且能和直接和workflow交互,可以解决我们能遇到的大多数问题。可惜这么牛bi的东西Microsfot可不会白送给你。无论是MOSS2007还是Office2007都要很多钞票才能搞定啊。没办法,只能自己想办法搞定这个问题。
  SharePoint展现页面是通过webpart来控制的,webpart会所有相关的template并且根据其内容生成html。SharePoint把所有的template都存放在SharePoint的安装目录Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\CONTROLTEMPLATES下面。文件DefaultTemplates.ascx里面就是存放了在不同scenario下面会使用到的templates。比如lID为ListForm的那段template。我们看到的view/edit list item的时候所看到的页面就是由它控制的。
  


<SharePoint:RenderingTemplate ID="ListForm" runat="server">
    <Template>
      <SPAN id='part1'>

            <SharePoint:InformationBar runat="server"/>

            -- 我想应该是页面的标题,显示当前item的brief信息

            <wssuc:ToolBar CssClass="ms-formtoolbar" id="toolBarTbltop" RightButtonSeparator="&nbsp;" runat="server">
                  <Template_RightButtons>
                        <SharePoint:NextPageButton runat="server"/>
                        <SharePoint:SaveButton runat="server"/>
                        <SharePoint:GoBackButton runat="server"/>
                  </Template_RightButtons>

            </wssuc:ToolBar>

         -- 根据不同情况会显示:OK Button, Close Button, Cancel Button


            <SharePoint:FormToolBar runat="server"/>
             -- Form工具栏:new item, edit item, delete item等等

            <TABLE class="ms-formtable" style="margin-top: 8px;" border=0 cellpadding=0 cellspacing=0 width=100%>
            <SharePoint:ChangeContentType runat="server"/>
            <SharePoint:FolderFormFields runat="server"/>
            <SharePoint:ListFieldIterator runat="server"/> (展现所有view字段的控件)
            <SharePoint:ApprovalStatus runat="server"/>
            <SharePoint:FormComponent TemplateName="AttachmentRows" runat="server"/>

            </TABLE>

            -- 这块就是显示list item内容的部分


            <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>
            <TABLE cellpadding=0 cellspacing=0 width=100% style="padding-top: 7px"><tr><td width=100%>
            <SharePoint:ItemHiddenVersion runat="server"/>
            <SharePoint:ParentInformationField runat="server"/>
            <SharePoint:InitContentType runat="server"/>
            <wssuc:ToolBar CssClass="ms-formtoolbar" id="toolBarTbl" RightButtonSeparator="&nbsp;" runat="server">
                  <Template_Buttons>
                        <SharePoint:CreatedModifiedInfo runat="server"/>
                  </Template_Buttons>
                  <Template_RightButtons>
                        <SharePoint:SaveButton runat="server"/>
                        <SharePoint:GoBackButton runat="server"/>
                  </Template_RightButtons>

            </wssuc:ToolBar>

            -- Form最下面的button:OK, Close, Cancel, Save..
            </td></tr></TABLE>
      </SPAN>

      <SharePoint:AttachmentUpload runat="server"/>

      -- 上传attachement的控件
    </Template>

</SharePoint:RenderingTemplate
  
  理论上来说只要修改相应的template就能改变页面展现的layout。不过这个DefaultTemplates文件是系统文件,在WSS更新的时候被覆盖掉,而且直接修改系统文件感觉也有点危险。还好 WSS本身支持RenderingTemplate的定制.只要在CONTROLTEMPLATES下新建一个ascx文件,在里面添加模板即可,新添加的模板会覆盖默认模板中同样ID定义的模板. 比如:
  1. 新创建一个文件CustomListForm.ascx文件,存放在CONTROLTEMPLATES目录下。
  2. 增加各文件头

<%@ Control Language="C#"  AutoEventWireup="false" %>
<%@Assembly Name="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@Register TagPrefix="SharePoint" Assembly="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" namespace="Microsoft.SharePoint.WebControls"%>
<%@Register TagPrefix="SPHttpUtility" Assembly="Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" namespace="Microsoft.SharePoint.Utilities"%>
<%@ Register TagPrefix="wssuc" TagName="ToolBar" src="~/_controltemplates/ToolBar.ascx" %>
<%@ Register TagPrefix="wssuc" TagName="ToolBarButton" src="~/_controltemplates/ToolBarButton.ascx" %>  
  3. 把DefaultTemplates里面ID为ListForm的那部分Copy到紧接着的后面。保存文件。
  4. 然后就可以根据需求修改文件,保存修改,然后重新启动IIS以后就可以看到效果了。

  看到了么!form下方的button被删除掉,虽然这个设计还算不错的,不过为了展示下效果之好委屈一下它,嘿嘿。
  
  虽说这个方法能解决一部分问题,但是更多问题来了:
  1. 这是个全局改动,会影响所有相关的地方,不能单独作用于某个list或者某个scenario
  2. Layout可以通过这个方法进行修改。但是怎么操作field级别的数据呢?field是通过ListFieldIterator这个control生成出来,紧紧通过修改template不能控制field内容的布局。
  So....let's have a break. I need to research more to get answers....
页: [1]
查看完整版本: 定制SharePoint表单