重新过一遍asp.net 2.0(C#)母页和主题

本文详细介绍了ASP.NET2.0中母版页的基本概念及使用方法,包括母版页与内容页间的数据传递、控件查找等。同时,深入探讨了如何利用主题功能统一管理网站样式,通过示例展示了不同主题的应用效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

介绍
母版页(MasterPage)就相当于模板页,挺简单的,没什么好说的。基于母版页的常用的功能有:母版页和内容页之间信息的传递,在内容页中用FindControl方法找到内容页中的控件等。另外,母版页是可以嵌套的。


关键
在内容页的头部加上母版页的强类型引用

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif --创建对母版页的强类型引用,并指定到母版页的虚拟路径-- %>
ExpandedBlockStart.gifContractedBlock.gif
<% dot.gif @ MasterType VirtualPath="~/MasterPage/MasterPage.master"  %>


1、内容页传递数据到母版页 - 母版页创建一个公共方法,然后内容页通过“Master.方法”来调用这个公共方法

2、母版页传递数据到内容页 - 母版页创建一个公共事件来传递数据,然后内容页处理这个事件

3、内容页中用FindControl方法找到内容页中的控件 - 用“Master.FindControl("ContentPlaceHolder1").FindControl("你要查找的控件ID")”来查找

4、嵌套母版页 - 说起来麻烦,看源码吧


示例
主母板页
Site.master

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Master Language="C#" AutoEventWireup="true" CodeFile="Site.master.cs" Inherits="Site"  %>
None.gif
< html  xmlns ="http://www.w3.org/1999/xhtml" >
None.gif
< head  id ="Head1"  runat ="server" >
None.gif    
< title > 重新过一遍ASP.NET 2.0(C#) </ title >
None.gif
</ head >
None.gif
< body >
None.gif    
< form  id ="form1"  runat ="server" >
None.gif        
< div >
None.gif            
< asp:ContentPlaceHolder  ID ="ContentPlaceHolder1"  runat ="server" >
None.gif            
</ asp:ContentPlaceHolder >
None.gif        
</ div >
None.gif    
</ form >
None.gif
</ body >
None.gif
</ html >
None.gif


次母板页
MasterPage/MasterPage.master

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Master Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true"
ExpandedBlockEnd.gif    CodeFile
="MasterPage.master.cs" Inherits="MasterPage_MasterPage" 
%>
None.gif
< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
None.gif    
< p >
None.gif        我是一个嵌套母版页
None.gif    
</ p >
None.gif    
< p >
None.gif        母版页中的内容
None.gif        
< asp:DropDownList  ID ="ddlMaster"  runat ="server"  DataSourceID ="XmlDataSource1"  DataTextField ="text"
None.gif            DataValueField
="value"  AutoPostBack ="True"  OnSelectedIndexChanged ="ddlMaster_SelectedIndexChanged" >
None.gif        
</ asp:DropDownList >< asp:XmlDataSource  ID ="XmlDataSource1"  runat ="server"  DataFile ="~/Config/DropDownListData.xml" >
None.gif        
</ asp:XmlDataSource >
None.gif    
</ p >
None.gif    
< p >
None.gif        内容页中的内容
None.gif        
< asp:ContentPlaceHolder  ID ="cph"  runat ="Server"   />
None.gif    
</ p >
None.gif
</ asp:Content >
None.gif


MasterPage/MasterPage.master.cs

None.gif using  System;
None.gif
using  System.Data;
None.gif
using  System.Configuration;
None.gif
using  System.Collections;
None.gif
using  System.Web;
None.gif
using  System.Web.Security;
None.gif
using  System.Web.UI;
None.gif
using  System.Web.UI.WebControls;
None.gif
using  System.Web.UI.WebControls.WebParts;
None.gif
using  System.Web.UI.HtmlControls;
None.gif
None.gif
public  partial  class  MasterPage_MasterPage : System.Web.UI.MasterPage
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
protected void Page_Load(object sender, EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif
ExpandedSubBlockEnd.gif    }

InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif    
/**//// <summary>
InBlock.gif    
/// 设置ddlMaster的选中索引
InBlock.gif    
/// 这个方法由内容页调用
InBlock.gif    
/// </summary>
ExpandedSubBlockEnd.gif    
/// <param name="index"></param>

InBlock.gif    public void SetddlMaster(int index)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        ddlMaster.SelectedIndex 
= index;
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
protected void ddlMaster_SelectedIndexChanged(object sender, EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
// ddlMaster的选中索引改变后,激发SelectedIndexChanged_ddlMaster事件
InBlock.gif
        SelectedIndexChanged_ddlMaster(thisnew CommandEventArgs(ddlMaster.SelectedItem.Text, ddlMaster.SelectedValue));
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
// 声明一个公共时间事件,让内容页用
InBlock.gif
    public event CommandEventHandler SelectedIndexChanged_ddlMaster;
ExpandedBlockEnd.gif}

None.gif


内容页
MasterPage/Test.aspx

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Page Language="C#" MasterPageFile="~/MasterPage/MasterPage.master" AutoEventWireup="true"
ExpandedBlockEnd.gif    CodeFile
="Test.aspx.cs" Inherits="MasterPage_Test" Title="MasterPage测试" 
%>
None.gif
ExpandedBlockStart.gifContractedBlock.gif
<% dot.gif --创建对母版页的强类型引用,并指定到母版页的虚拟路径-- %>
ExpandedBlockStart.gifContractedBlock.gif
<% dot.gif @ MasterType VirtualPath="~/MasterPage/MasterPage.master"  %>
None.gif
< asp:Content  ID ="Content1"  ContentPlaceHolderID ="cph"  runat ="Server" >
None.gif    
< asp:dropdownlist  id ="ddlPage"  runat ="server"  datasourceid ="XmlDataSource1"  datatextfield ="text"
None.gif        datavaluefield
="value"  autopostback ="True"  onselectedindexchanged ="ddlPage_SelectedIndexChanged" >
None.gif    
</ asp:dropdownlist >
None.gif    
< asp:xmldatasource  id ="XmlDataSource1"  runat ="server"  datafile ="~/Config/DropDownListData.xml" >
None.gif    
</ asp:xmldatasource >
None.gif
</ asp:Content >
None.gif


MasterPage/Test.aspx.cs

None.gif using  System;
None.gif
using  System.Data;
None.gif
using  System.Configuration;
None.gif
using  System.Collections;
None.gif
using  System.Web;
None.gif
using  System.Web.Security;
None.gif
using  System.Web.UI;
None.gif
using  System.Web.UI.WebControls;
None.gif
using  System.Web.UI.WebControls.WebParts;
None.gif
using  System.Web.UI.HtmlControls;
None.gif
None.gif
public  partial  class  MasterPage_Test : System.Web.UI.Page
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
protected void Page_Load(object sender, EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
// 在内容页用FindControl方法找到内容页中的控件
InBlock.gif
        DropDownList ddl = new DropDownList();
InBlock.gif        ddl 
= Master.Master.FindControl("ContentPlaceHolder1").FindControl("cph").FindControl("ddlPage"as DropDownList;
InBlock.gif        Master.Master.FindControl(
"ContentPlaceHolder1").FindControl("cph").Controls.Add(new LiteralControl("<br />内容页中的DropDownList的ClientID是:" + ddl.ClientID));
InBlock.gif
InBlock.gif        
// 增加一个事件处理,该事件是在母版页定义的一个公共事件
InBlock.gif
        Master.SelectedIndexChanged_ddlMaster += new CommandEventHandler(Master_SelectedIndexChanged_ddlMaster);
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
void Master_SelectedIndexChanged_ddlMaster(object sender, CommandEventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
// CommandEventArgs已经在母版页中的公共事件“SelectedIndexChanged_ddlMaster”中指定
InBlock.gif
        string selectedText = e.CommandName;
InBlock.gif        
string selectedValue = e.CommandArgument.ToString();
InBlock.gif
InBlock.gif        ddlPage.SelectedValue 
= selectedValue;
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
protected void ddlPage_SelectedIndexChanged(object sender, EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
// 调用母版页的方法
InBlock.gif
        Master.SetddlMaster(ddlPage.SelectedIndex);
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

None.gif



OK
[源码下载]


介绍
使用 ASP.NET 2.0 的“主题”功能,可以将样式和布局信息分解为单独的文件组,统称为“主题”。然后,主题可应用于任何站点,影响站点中页和控件的外观。这样,通过更改主题即可轻松地维护对站点的样式更改,而无需对站点各页进行编辑。还可与其他开发人员共享主题。


关键
1、在web site中添加App_Themes文件夹,可以在每个主题文件加内添加.skin文件、.css文件(指定主题后会自动加载主题下所有.css文件)或者图片文件

2、在web.config的<system.web>元素下的<pages>元素下设置theme或者styleSheetTheme属性(针对全局);在页的@Page指令里设置Theme或者StylesheetTheme属性(针对当前页)

3、Theme定义的样式不可以覆盖;StylesheetTheme定义的样式可以覆盖

4、.skin文件里不设置SkinId则就是默认的,设置了SkinId后则对应控件的SkinId属性

5、动态修改Page的Theme要在Page_PreInit方法中实现


示例
Blue主题

None.gif < asp:Label  runat ="server"  BackColor ="blue"  ForeColor ="white"   />
None.gif
< asp:Label  runat ="server"  BackColor ="DarkBlue"  ForeColor ="white"  SkinId ="Dark"   />
None.gif
ExpandedBlockStart.gifContractedBlock.gif
<% dot.gif --ImageUrl如下设置则解析到该主题下的Images文件夹的pic.jpg文件-- %>
None.gif
< asp:Image  runat ="server"  ImageUrl ="Images/pic.jpg"   />


Red主题

None.gif < asp:Label  runat ="server"  BackColor ="red"  ForeColor ="white"   />
None.gif
< asp:Label  runat ="server"  BackColor ="DarkRed"  ForeColor ="white"  SkinId ="Dark"   />
None.gif
ExpandedBlockStart.gifContractedBlock.gif
<% dot.gif --ImageUrl如下设置则解析到该主题下的Images文件夹的pic.jpg文件-- %>
None.gif
< asp:Image  runat ="server"  ImageUrl ="Images/pic.jpg"   />


主题测试-Theme
Themes/Theme.aspx

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Theme.aspx.cs"
ExpandedBlockEnd.gif    Inherits
="Themes_Theme" Title="主题测试-Theme" Theme="Blue" 
%>
None.gif
None.gif
< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
None.gif    
< p >
None.gif        在页头部分指定Theme="Blue"
</ p >
None.gif    
< p >
None.gif        相关主题文件,我觉得最好把样式写在css里然后设置控件的CssClass属性
None.gif        
< br  />
None.gif        
&lt; asp:Label ID="Label1" runat="server" BackColor="blue" ForeColor="white" / &gt;
None.gif        
< br  />
None.gif        
&lt; asp:Label ID="Label2" runat="server" BackColor="DarkBlue" ForeColor="white"
None.gif        SkinId="Dark" /
&gt;
None.gif    
</ p >
None.gif    
< p >
None.gif        
< asp:Label  ID ="lbl"  runat ="Server"  Text ="不做任何设置(使用主题中的没设置SkinId的样式)"   />
None.gif    
</ p >
None.gif    
< p >
None.gif        
< asp:Label  ID ="lbl2"  runat ="Server"  Text ="设置BackColor为black(因为设置的是页的Theme属性,所以无法覆盖原有样式)"  BackColor ="black"   />
None.gif    
</ p >
None.gif    
< p >
None.gif        
< asp:Label  ID ="lbl3"  runat ="Server"  Text ="主题测试设置SkinID为dark(指定SkinId)"  SkinID ="dark"   />
None.gif    
</ p >
None.gif
</ asp:Content >
None.gif


主题测试-StylesheetTheme
Themes/StylesheetTheme.aspx

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="StylesheetTheme.aspx.cs"
ExpandedBlockEnd.gif    Inherits
="Themes_StylesheetTheme" Title="主题测试-StylesheetTheme" StylesheetTheme="Red" 
%>
None.gif
None.gif
< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
None.gif    
< p >
None.gif        在页头部分指定StylesheetTheme="Red"
</ p >
None.gif    
< p >
None.gif        相关主题文件,我觉得最好把样式写在css里然后设置控件的CssClass属性
None.gif        
< br  />
None.gif        
&lt; asp:Label ID="Label1" runat="server" BackColor="red" ForeColor="white" / &gt;
None.gif        
< br  />
None.gif        
&lt; asp:Label ID="Label2" runat="server" BackColor="DarkRed" ForeColor="white" SkinId="Dark"
None.gif        /
&gt;
None.gif    
</ p >
None.gif    
< p >
None.gif        
< asp:Label  ID ="lbl"  runat ="Server"  Text ="不做任何设置(使用主题中的没设置SkinId的样式)"   />
None.gif    
</ p >
None.gif    
< p >
None.gif        
< asp:Label  ID ="lbl2"  runat ="Server"  Text ="设置BackColor为black(因为设置的是页的StylesheetTheme属性,所以无法覆盖原有样式)"  BackColor ="black"   />
None.gif    
</ p >
None.gif    
< p >
None.gif        
< asp:Label  ID ="lbl3"  runat ="Server"  Text ="主题测试设置SkinID为dark(指定SkinId)"  SkinID ="dark"   />
None.gif    
</ p >
None.gif
</ asp:Content >
None.gif


主题测试-动态加载主题
Themes/Dynamic.aspx

ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Dynamic.aspx.cs"
ExpandedBlockEnd.gif    Inherits
="Themes_Dynamic" Title="主题测试-动态加载主题" 
%>
None.gif
None.gif
< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
None.gif    
< p >
None.gif        相关.skin文件内容如下:
&lt; asp:Image runat="server" ImageUrl="Images/pic.jpg" / &gt;
None.gif    
</ p >
None.gif    
< p >
None.gif        
< href ="?theme=blue" > 蓝色主题 </ a >   &nbsp; < href ="?theme=red" > 红色主题 </ a >
None.gif    
</ p >
None.gif    
< p >
None.gif        该Image控件应用主题中的样式,包括ImageUrl
None.gif        
< br  />
None.gif        
< asp:Image  ID ="img"  runat ="server"   />
None.gif    
</ p >
None.gif
</ asp:Content >
None.gif


Themes/Dynamic.aspx.cs

None.gif using  System;
None.gif
using  System.Data;
None.gif
using  System.Configuration;
None.gif
using  System.Collections;
None.gif
using  System.Web;
None.gif
using  System.Web.Security;
None.gif
using  System.Web.UI;
None.gif
using  System.Web.UI.WebControls;
None.gif
using  System.Web.UI.WebControls.WebParts;
None.gif
using  System.Web.UI.HtmlControls;
None.gif
None.gif
public  partial  class  Themes_Dynamic : System.Web.UI.Page
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
protected void Page_Load(object sender, EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
protected void Page_PreInit(object sender, System.EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
// 动态修改Page的Theme要在Page_PreInit方法中实现
InBlock.gif
        if (!String.IsNullOrEmpty(Request.QueryString["theme"]))
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            Page.Theme 
= Request.QueryString["theme"];
ExpandedSubBlockEnd.gif        }

InBlock.gif        
else
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            Page.Theme 
= "blue";
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

None.gif



OK
[源码下载]

转载于:https://www.cnblogs.com/hulu/archive/2007/06/27/797850.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值