Asp.net模板页的使用

http://msdn.microsoft.com/zh-cn/library/wtxbf3hh.aspx

,创建模板页

     

1)首先我们先建立一个网站(图一),ASP.net  模板页 - cyb_china - cyb_china的博客

2)在此项目上添加一个模板页,在网站上“右击鼠标”,选择“添加新相”,找到“模板页”(图二),名称自己定,语言当然就不用说了,然后点击添加就可以了!

ASP.net  模板页 - cyb_china - cyb_china的博客ASP.net  模板页 - cyb_china - cyb_china的博客

3)现在我们再仔细的看一下这个模板页到底有什么功能,到底有什么神秘之处!我们双击如图所示的MasterPage.master文件,查看其 原文件,我们首先看到第一行就是“<%@ Master Language="C#" AutoEventWireup="true" CodeFile="MasterPage.master.cs" Inherits="MasterPage" %>”,这句话是模板页的声明,如果我们仔细一点的话就会发现,它的声明和普通页面的声明很相似,主要有一下几点:1、模板页是以master开始,后缀是“.master”,而普通的页面是以page开始的,后缀是“.aspx”,再一个很大的区别就是:在模板页中存在一个“ContentPlaceHolder”控件,这个控件就是用来填充内容页的地方,而普通的页面是没有的!(图四)我们可以在模板页的地方添加各种固定的信息如页面的logo或者是声明等!现在我们为这个模板页添加一个内容页,来看一下效果。

ASP.net  模板页 - cyb_china - cyb_china的博客                       ASP.net  模板页 - cyb_china - cyb_china的博客

具体操作如下:我们在内容页的位置右击鼠标,选择“添加内容页”(图六)就可以。此时,我们会看到内容页的源码区,及其简单,就三句话。

其中“MasterPageFile="~/MasterPage.master"”这句话是定义是模板页,

再看下一行“<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" Runat="Server">

                    </asp:Content>”,

           “ContentPlaceHolderID="ContentPlaceHolder1"”为我们指定了模板页中的可以添加内容页的ContentPlaceHolder,有时候我们的模板页会不只有一个ContentPlaceHolder,我们要根据自己的需要来选择!我们选择“设计”模式,来看一下效果,只有内容页的地方允许我们编辑,这就实现了模板页的作用!假如我们的内容页也想利用模板页的内容,我们可以点击ContentPlaceHolder右上角的那个小三角,然后选择“默认为模板页内容就可以了”(图八)! ASP.net  模板页 - cyb_china - cyb_china的博客

在母版页中,可以添加多个ContentPlaceHolder控件,通过在工具箱的标准栏中选择ContentPlaceHolder,拖动到母版页中。在ContentPlaceHolder区域中,也可以直接输入内容或添加ASP.NET控件,ContentPlaceHolder区域中的内容将作为内容页的默认内容呈现。

2,使用模板页

1),选择网站名称,并单击右键,选择“添加新项”命令,在模板列表中选择“WEB窗体”。在添加新项窗体的右下角有两个复选框。确保选中“选择母版页”,复选框。如图:ASP.net  模板页 - cyb_china - cyb_china的博客

2),接下来弹出选择母版也窗口,选择你需要的母版也。如图:ASP.net  模板页 - cyb_china - cyb_china的博客

3),保存后,在新建的WEB页,即内容页。在显示的时候会把母版面的内容一起以水印淡化的形式显示出来,而在母版页中的ContentPlaceHolder控件区域会被内容页面中的Content控件替换,如图:ASP.net  模板页 - cyb_china - cyb_china的博客

 

一、在母版页中编写后台代码,访问母版页中的控件:

    与普通的aspx页面一样,双击按钮即可编写母版页中的代码

   

二、在内空页面中编写后台代码,访问内容页面中的控件:

    与普通的aspx页面一样,双击按钮即可编写母版页中的代码

   

三、在内容页面中编写代码访问母版页中的控件:

    在内容页面中有个Master对象,它是MasterPage类型,它代表当前内容页面的母版页。通过这个对象的FindControl方法,我们可以找到母版面中的控件,这样就可以在内容页面中操作母版页中的控件了。

        TextBox txt = (TextBox)((MasterPage)Master).FindControl("txtMaster");

        txt.Text = this.txtContent1.Text; ;

       

四、在内容页面中编写代码访问母版页中的属性和方法:

    仍可能通过Master对象进行访问,只不过在这里要把Master对象转换成具体的母版页类型,然后再调用母版页中的属性和方不法。

    这里要说明的是:母版页中要被内容页面调用的属性和方法必须是Public修改的。否则无法调到。

        假设母版页中有下面的属性和方法:

        public string TextValue

        {

            get

            {

                return this.txtMaster.Text;

            }

            set

            {

                this.txtMaster.Text = value;

            }

        }

        public void show(string str)

        {

            txtMaster.Text = str;

        }

       在内容页面中可以通过下代的代码来实现对母版页中方法的调用:

        ((MasterPage_MP)Master).show(this.txtContent1.Text);

        ((MasterPage_MP)Master).TextValue = this.txtContent1.Text;

       

五、在母版页中访问内容页面的控件:

    在母版页中可以通过在ContentPlaceHolder控件中调用FindControl方法来取得控件,然后对控件进行操作。

    ((TextBox)this.ContentPlaceHolder1.FindControl("txtContent1")).Text = this.txtMaster.Text;

   

六、在母版页中访问内容页面中的方法和属性:

    在母版页中调用子页面中的属性和方法有点难度,因为我们无法像上一步中那样通过FindControl来找到方法和属性。

    于是我们想到在母版面的声明指示符中加入下面的代码:

        <%@ Reference Page="~/MasterPage/Show1.aspx" %>

    在运行的时候回发现有错误,错误的内容是“无法实现循环引用”。这是因为默认在子页面中引用了母版页,你也就不能再在母版页中引用子页面了。

    我在网上也没找到更好的解决方法,但这使我们想起C#是的“反射”,它可以使我们动态获取页面对象,并且可以调用它的属性和方法。

    代码如下:

        Type t = this.ContentPlaceHolder1.Page.GetType();

        PropertyInfo pi = t.GetProperty("ContentValue"); //获取ContentValue属性

        pi.SetValue(this.ContentPlaceHolder1.Page,this.txtMaster.Text,null);    //给属性赋值

       

        MethodInfo mi = t.GetMethod("SetValue"); //获取SetValue()方法

        object[] os = new object[1];   //建造输入参数

        os[0] = txtMaster.Text;

        mi.Invoke(this.ContentPlaceHolder1.Page, os);    //调用SetValue方法

       

七、在有多个内容页面使用母版面的情况下,在母版页中根据不同的内容页面实现不同的操作

    在母版页中可以加入多个不同的内容页面,但在设计期间,我们无法知道当前运行的是哪个内容页面。所以只能通过分支判断当前运行的是哪个子页面,来执行不同的操作。这里也用到了反射的知识。

    代码如下:

        string s = this.ContentPlaceHolder1.Page.GetType().ToString();   //取出内容页面的类型名称

        if (s == "ASP.default17_aspx")   //根据不同的内容页面类型执行不同的操作

        {

            ((TextBox)this.ContentPlaceHolder1.FindControl("TextBox2")).Text = "MastPage";

        }

        else if (s == "ASP.default18_aspx")

        {

            ((TextBox)this.ContentPlaceHolder1.FindControl("TextBox2")).Text = "Hello MastPage";

        }

八、在母版面与内容页面中JS代码的操作

    在母版页或内容页面中的控件运行之后会自动生成ID,如文本框的ID是txtContent1,在运行之后ID会自动变为ctl00_ContentPlaceHolder2_txtContent1,name属性会变为ctl00$ContentPlaceHolder2$txtContent1。

    在JS代码中,我们用document.getElementById()方法,根据id取得控件对象的时候,应当使用ctl00_ContentPlaceHolder2_txtContent1这个ID名,否则会产生“未找到对象”的异常。

   (车延禄)

母版页运行机制

母版页仅仅是一个页面模板,单独的母版页是不能被用户所访问的。单独的内容页也不能够使用。母版页和内容页有着严格对应关系。母版页中包含多少个ContentPlaceHolder控件,那么内容页中也必须设置与其相对应的Content控件。当客户端浏览器向服务器发出请求,要求浏览某个内容页面时,ASP.NET引擎将同时执行内容页和母版页的代码,并将最终结果发送给客户端浏览器。

母版页和内容页的运行过程可以概括为以下5个步骤。

(1)用户通过键入内容页的URL来请求某页。

(2)获取内容页后,读取@ Page指令。如果该指令引用一个母版页,则也读取该母版页。如果是第一次请求这两个页,则两个页都要进行编译。

(3)母版页合并到内容页的控件树中。

(4)各个Content控件的内容合并到母版页中相应的ContentPlaceHolder控件中。

(5)呈现得到结果页。

母版页和内容页事件顺序

ASP.net  模板页 - cyb_china - cyb_china的博客

 

(1)母版页中控件Init事件;

(2)内容页中Content控件Init事件;

(3)母版页Init事件;

(4)内容页Init事件;

(5)内容页Load事件;

(6)母版页Load事件;

(7)内容页中Content控件Load事件;

(8)内容页PreRender事件;

(9)母版页PreRender事件;

(10)母版页控件PreRender事件。

(11)内容页中Content控件PreRender事件。

使用母版页的优点:

(1)有利于站点修改和维护,降低开发人员的工作强度

(2)有利于实现页面布局

(3)提供一种便于利用的对象模型

posted @ 2011-05-15 11:00  microsoftzhcn  阅读(997)  评论(0编辑  收藏  举报