导航

SharePoint也可以使用CODE-BEHIND

Posted on 2008-02-15 08:51  zhalin  阅读(3082)  评论(13编辑  收藏  举报

用VS开发ASP.NET页面的时候,一切都非常的傻瓜式。在工具栏拖几个控件,放一个BUTTON,双击一下BUTTON则VS自动帮我们打开了一个CODE-BEHIND的CLASS,我们似乎什么都可以不要管,写几行简单的代码按一下F5,就好了。被VS养的如果离开了它还真不会写代码了。话说回来Visual Studio真是微软出品的最好的开发产品了。

那么现在这一切搬到SharePoint里去,我们可以不可以使用这个code-behind的技巧呢?答案是肯定的,只不过VS不能像在ASP.NET里那样自动帮我们做所有的事情了,我们必须亲自动手来加一些简单的代码。

大家知道,传统ASP.NET页面是基于文件系统的,而SharePoint页面是基于数据库的(Customized之后),并且任意一个SharePoint aspx页面都是MasterPage和LayoutPage互相结合产生的。一个通常的SharePoint网站可能会有1个MasterPage以及N多的LayoutPage,我们要处理的FORM便几乎一定是存在于某个LayoutPage中的。那么在这种情况下,我们的code behined Class必须要从 Microsoft.SharePoint.Publishing.PublishingLayoutPage继承过来。然后根据FORM中的控件ID来声明相应的变量。比如在FORM HTML中是:

<form id="form1" runat="server">
    <div>
        <asp:Label ID="LabelName" runat="server" Text="Name"></asp:Label>
        <asp:TextBox ID="TextBoxName" runat="server"></asp:TextBox>
        <asp:Button ID="Submit" runat="server" Text="Submit" />
        <asp:Label ID="LabelDisplay" runat="server"></asp:Label>
    </div>
</form>

那么我们的CODE Class就该像这样:(代码片段)

namespace namespace1
{
    public class FormHandler : Microsoft.SharePoint.Publishing.PublishingLayoutPage
    {
        protected TextBox TextBoxName;
        protected Label LabelDisplay;
        protected Button Submit;
        protected override void OnInit(EventArgs e)
        {
            Submit.Click += new EventHandler(Submit_Click);
        }
        protected void Submit_Click(object sender, EventArgs e)
        {
            LabelDisplay.Text = "You entered: " + TextBoxName.Text;
        }
    }
}

注意在声明FORM控件时,不可以省略protected关键字不然程序会出错因为找不到FORM中的相应控件。

将它编译成DLL,并发布到BIN(如果是发布到GAC则需要强命名)。为了让LayoutPage认识这个DLL,我们要在LayoutPage最上面重写 Page Directive:(比如这样)

<%@ Page meta:progid="SharePoint.WebPartPages.Document" Language="C#"  Inherits="namespace1.FormHandler,  FormHandler, Version=1.0.0.0,  Culture=neutral, PublicKeyToken=null" %>

其中Inherits=<NamespaceName.Classname+FullAssemblyName>,需要从该DLL中取得相应的信息,譬如用Reflector来打开该DLL文件就是一个非常好的办法。注意看这里包含5个部分,后4部分可以用Reflector轻松得到,第一部分用这个格式:NamespaceName.ClassName

好,现在当用户单击Submit按钮的时候,我们的代码就会被调用了,至此完成了在SharePoint中Code-Behind的实现。