乐趣区

CW循环世界系统APP开发制作

相信大家都用过 asp.net 2.0 下的 CW 循环世界系统 APP 开发(T:I8O、2853、296O V 黎灿)嵌套的 masterpage 功能,该功能很强大,可以让用户先制作出模版页后,然后很容易地套用到其他页面中去。而且模版页还可以嵌套的,但嵌套后的模版页,我们会发觉有一个问题,那就是当使用嵌套的模版页后,在设计视图状态下,是没办法对其进行可视化操作的,那么如何解决这个问题呢?

我找了下老外的 blog, 找到了老外提供的一个方法,暂且可以绕个弯来解决该问题,下面讲解一下:
我们可以写一个基类,叫 basepage.cs,放在 app_code 目录下,在这个类中,添加一个叫
runtimeMasterPageFile 的属性,是一个字符串类型,指定在运行期间才用哪一个模版文件,并且重写 OnPreInit

方法,代码如下:

public class BasePage : System.Web.UI.Page
{

private string runtimeMasterPageFile;
public string RuntimeMasterPageFile
{
    get
    {return runtimeMasterPageFile;}
    set
    {runtimeMasterPageFile = value;}
}

protected override void OnPreInit(EventArgs e)
{if (runtimeMasterPageFile != null)
    {this.MasterPageFile = runtimeMasterPageFile;}

    base.OnPreInit(e);
}

}

接着,我们构造一个叫 mainmaster.master 的模版页,里面随便搞一个 header 和 footer 的信息,中间留一个
叫 MainContent 的 contentplaceholder, 然后再建一个叫 submaster.master 的模版页,其中的
MasterPageFile=”~/MainMaster.master”,以套用 mainmaster 模版页,其中放一个一行两列的表格,如下:
<asp:Content ID=”foo” ContentPlaceHolderId=”MainContent” runat=”server”>

<table>
    <tr>
        <td width="300">
        
            Left Column in SubMaster
            <br />
        
            <asp:ContentPlaceHolder ID="LeftColumn" runat="server">
            </asp:ContentPlaceHolder>
        </td>
        <td>
       
            Right Column in SubMaster
            <br />            
        
            <asp:ContentPlaceHolder ID="RightColumn" runat="server">
            </asp:ContentPlaceHolder>
        </td>
    </tr>

</table>

</asp:Content>
最后,在一个 aspx 页面中,这样指定
<%@ Page Language=”C#” MasterPageFile=”” RuntimeMasterPageFile=”SubMaster.master” CodeFileBaseClass=”BasePage” AutoEventWireup=”true” CodeFile=”Default.aspx.cs” Inherits=”_Default” Title=”Untitled Page” %>
可以看到,在这里,我们不设置 masyterpage 的属性,而是指定了 RuntimeMasterPageFile 的属性为
submaster.master, 这个是在运行时候才加载的模版,而 codefilebaseclass 属性指定了我们刚才写
的那个类 basepage.cs, 这样,我们就可以在这个 ASPX 的设计视图状态下看到拉,可以拖拉设计了。
要注意的是,根据微软的说法,听说要到下一个版本的 VISUAL STUDIO, 才能完全支持模版嵌套时的完全设计视图
状态的切换哦

退出移动版