欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP.Net巧用窗体母版页

程序员文章站 2022-11-28 11:46:31
背景:每个网页的基本框架结构类似: 浏览网站的时候会发现,好多网站中,每个网页的基本框架都是一样的,比如,最上面都是网站的标题,中间是内容,最下面是网站的版权、开发提供商等信息...

背景:每个网页的基本框架结构类似:

浏览网站的时候会发现,好多网站中,每个网页的基本框架都是一样的,比如,最上面都是网站的标题,中间是内容,最下面是网站的版权、开发提供商等信息:

ASP.Net巧用窗体母版页

在这些网页中,表头、底部的样式和内容都是一样的,不同的只是中间的内容。喎? f/ware/vc/"="" target="_blank" class="keylink">vcd4kpha+icagicaginlytmvu2tbg1/fn+nw+yrgjrl/j0ts9q9xi0km5ss2stcs2q873t9ba67p2wlsjrlfftb2hslswzoxeuldm0rohsdbqo6zu2tdo0qq1xmqxuvlhtszxvs2/ydluoam8l3a+cjxwpjxicj4kpc9wpgo8adm+icagicagicagica8c3ryb25npsfj08o0smzlxliw5s/uo7o8l3n0cm9uzz48l2gzpgo8cd4gicagicagz8ld5r7nv6rkvndqtq+jqlg+zstkx9luvmlzdwfsu3r1zglvmjaxm9f3zqqx4lpmu7e+s6osv8ne3ntaxlpqqbk91ujt68bky/uw5rg+09dl+bp2youjrmfr19tq0nei0ukjqao6pc9wpgo8cd4gicagicagidghottaz+7ev9bqzo2809k7v2vitldm5cs4sobss3rlc3qutwfzdgvyo7rt0rz8z+7ev6gqzo2806gq0mk9qm/uoapxzwk0smzlxliw5tkzo7s8l3a+cjxwpjwvcd4kphbyzsbjbgfzcz0="brush:java;">

:contentplaceholder id="head" runat="server">

2、在窗体母版页test.master的

标记之间添加css、js等引用(这里先只添加css文件为例):

              
    
    
    
    
3、编辑窗体母版页test.master,添加每个网页的公共内容(此处以网页布局为上图的布局为例,三个p的css样式就暂不说明):

    
        

某某某网站

版权所有:******


4、在每个网页中嵌套窗体母版页test.master:右键项目—添加—新建项—包含母版页的web窗体test.aspx,在选择母版页对话框中选择test.master,确定,生成的网页为:




此时这个窗体test.aspx和母版页test.master的运行效果是一样的,接下来就是加上每个网页中的不同的内容。

5、此时,网页test.aspx中contentplaceholderid=“head”和contentplaceholderid=“contentplaceholder”的就相当于母版页test.master中对应的。所以假如每个网页都会有相同部分,就可以把相同部分写在母版页的相应位置,而将每个网页的不同内容写在contentplaceholderid=“contentplaceholder”的中。

比如,第4步中,这个test.aspx已经嵌套了这个样式,它的主题内容为 “ 网站内容 网站内容 网站内容 网站内容…… ”,则test.aspx中的代码为:




    

网站内容 网站内容 网站内容 网站内容……

假如我又建了一个名为test1.aspx的网页,除了与test1.aspx中的主体内容不一样之外,其他都一样,那么就可以让test1.aspx嵌套母版页test.master,代码为:




    

网站内容1 网站内容1 网站内容1 网站内容1……

拓展:母版页嵌套母版页

当整个网站内的所有网页并不是这一种样式,而是一个大的网站分为几个栏目,每个栏目中网页的风格样式统一,这时候可以用母版页来嵌套母版页 :


现在再建立一个母版页(我在这里给它取名为“子母版页”),用它来嵌套上面的母版页test.master,代码为:



    


    
    
         
    
注意,代码第一行的masterpagefile=“~/test.master”即要嵌套的母版页的地址,“~”为当前目录。


嵌套网页母版项的好处:

可以利用visualstudio中的窗体母版页来将每个页面中相同的部分进行封装,在创建相同结构的网页时,便可以直接嵌套这个窗体母版页,避免了代码的重复,提高了代码的复用性;另外,如果要修改一个栏目甚至整个网站的风格,则只需修改母版页以及母版页中引入的<script>等文件,提高了代码的可维护性,充分体现了oop的思想。

喎?>