经过前两个文章的努力,我们已经能看到仅仅是一个空空的页面,在开发我们想要的功能之前一个合理的布局是非常必要的.
打开几个原有页面的原代码我们分现,CS的布局,全部是类似于,
< CS:MPContent id ="bcr" runat ="server" >
1
</ CS:MPContent >
< CS:MPContent id ="lcr" runat ="server" >
2
</ CS:MPContent >
< CS:MPContent id ="rcr" runat ="server" >
3
</ MPContent >
</ CS:MPContainer >
都是一个MPContainer包含了数个MPContent
我们可以把MPContainer看成是一个页面容器(从英文的字面意思上也就是这个意思),MPContent就是用来显示内容的区域,但是几个MPContent是怎么来确定各自在整个页面中的位置的呢?
可以看到,每个MPContent都有一个id属性,第个id属性都有一个bcr和lcr等不同的值.要弄清楚为什么只要设置一个相应的值,我们的内容就会自动出现在相应的位置,我们有必要了解一下CS所的模版机制,CS采用的是MetaBuilders.WebControls.MasterPages这个第三方的组件,在\source\Controls\ContentContainer.cs中CS采用了一个代理模式把这个组件引入,为什么用代理模式,说句古话叫以不变应万变,不用但心MetaBuilders.WebControls.MasterPages一个接口或一个方法的变更而要对我们的程序大动干戈.具体代理模式的好处还是请各位自已查查相关资料吧,CNBLOG上有许多这方面的文章,我这里就不细说了
打个ContentContainer.cs我们可以看到
public class MPRegion : MetaBuilders.WebControls.MasterPages.Region{} //为CS的中的控件注册位置,就是占个座,打个比方说我们国家刚开过的人大代表会议,不是每个桌子上都有个姓名牌么上面写着XXX,开会的时候XXX来了,就要坐在这个位置,而且这个位置只能坐一个人,坐两个人就挤了,在CS中也一样,第个MPRegion定义一个"ID"比如id="bcr"它就是哪块牌子,在MPContent中的id="bcr"中内容就要显示在这个位置,它就相当于开会的人了
public class MPContent : MetaBuilders.WebControls.MasterPages.Content{} 这个就是用来包括内容和控件的容器
public class MPForm : MetaBuilders.WebControls.MasterPages.NoBugForm {} 这个用来在客户端生成表单
了解到了这里,我们可能会疑问,为什么我们的LocalPhotosMaster.ascx中没有定义一个相应的MPRegion了,但是我们的内容还是正解的显示出来了, 这是因为,CS中第一个子模版都是继续自\source\Web\Themes\default\Masters\Master.ascx这个主模版,打开它就可以看到这些个MPRegion的定义了,
2 <% @ Import Namespace="CommunityServer.Components" %>
3 <% @ Register TagPrefix="CS" Namespace="CommunityServer.Controls" Assembly="CommunityServer.Controls" %>
4 <% @ Register TagPrefix="Blog" Namespace="CommunityServer.Blogs.Controls" Assembly="CommunityServer.Blogs" %>
5 <% @ Register TagPrefix="CSD" Namespace="CommunityServer.Discussions.Controls" Assembly="CommunityServer.Discussions" %>
6 <% @ Register TagPrefix="TWC" Namespace="Telligent.Web.UI" Assembly="Telligent.Web.UI" %>
7 <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd" >
8 < html xmlns ="http://www.w3.org/1999/xhtml" xml:lang ="en" lang ="en" >
9 < CS:MPRegion id ="HeaderRegion" runat ="server" >
10 < CS:Head runat ="Server" >
11 < meta http-equiv ="Content-Type" content ="text/html; charset=UTF-8" />
12 < CS:Style id ="UserStyle" runat ="server" visible = "true" />
13 < CS:Style id ="s2" runat ="server" visible = "true" Href ="../style/Common.css" />
14 < CS:Style runat ="server" Href ="../style/common_print.css" media ="print" />
15 < CS:Script id ="s" runat ="server" />
16 </ CS:Head >
17 </ CS:MPRegion >
18 < body >
19 < CS:MPForm runat ="server" >
20 < TWC:Modal runat ="server" CssClasses ="CommonModal" TitleCssClasses ="CommonModalTitle" CloseCssClasses ="CommonModalClose" ContentCssClasses ="CommonModalContent" FooterCssClasses ="CommonModalFooter" ResizeCssClasses ="CommonModalResize" MaskCssClasses ="CommonModalMask" LoadingUrl ="~/utility/loading.htm" />
21 < CS:MPRegion id ="bscr" runat ="server" />
22 < div id ="CommonOuter" >< div id ="Common" >
23 < div id ="CommonHeader" >
24 < CS:MPRegion id ="bhcr" runat ="server" >
25 < CS:TitleBar runat ="server" id ="t" />
26 </ CS:MPRegion >
27 </ div >
28
29 < div id ="CommonBody" >
30 < table cellspacing ="0" cellpadding ="0" border ="0" width ="100%" id ="CommonBodyTable" >
31 < tr >
32 < td valign ="top" id ="CommonLeftColumn" >
33 < CS:MPRegion id ="lcr" runat ="server" />
34 </ td >
35 < td valign ="top" width ="100%" id ="CommonBodyColumn" >< table cellpadding ="0" cellspacing ="0" border ="0" style ="table-layout: fixed;" width ="100%" >< tr >< td >
36 < CS:MPRegion id ="bcr" runat ="server" />
37 </ td ></ tr ></ table ></ td >
38 < td valign ="top" id ="CommonRightColumn" >
39 < CS:MPRegion id ="rcr" runat ="server" />
40 </ td >
41 </ tr >
42 </ table >
43 </ div >
44 < div id ="CommonFooter" >
45 < CS:MPRegion id ="BodyFooterRegion" runat ="server" >
46 < CS:Footer runat ="server" id ="Footer1" />
47 </ CS:MPRegion >
48 </ div >
49 </ div ></ div >
50 </ CS:MPForm >
51 < CS:MPRegion id ="outsidetheform" runat ="server" />
52 </ body >
53 </ html >
54
当然如我们相要显示更多的内容可以在自己的子模版内添加MPRegion来增加一些座位