ASP.Net巧用窗體母版頁(yè)實(shí)例
本文實(shí)例講述了ASP.Net巧用窗體母版頁(yè)的方法。分享給大家供大家參考。具體分析如下:
背景:每個(gè)網(wǎng)頁(yè)的基本框架結(jié)構(gòu)類似:
瀏覽網(wǎng)站的時(shí)候會(huì)發(fā)現(xiàn),好多網(wǎng)站中,每個(gè)網(wǎng)頁(yè)的基本框架都是一樣的,比如,最上面都是網(wǎng)站的標(biāo)題,中間是內(nèi)容,最下面是網(wǎng)站的版權(quán)、開(kāi)發(fā)提供商等信息:
在這些網(wǎng)頁(yè)中,表頭、底部的樣式和內(nèi)容都是一樣的,不同的只是中間的內(nèi)容。
因此在制作網(wǎng)站時(shí),可以將這些共同的東西分離出來(lái),放到“窗體母版頁(yè)”中,在需要的時(shí)候嵌套就可以。
巧用窗體母版項(xiàng):
下面就開(kāi)始行動(dòng)(本文是以VisualStudio2013作為編程環(huán)境,可能在某些步驟與其他版本有所出入,請(qǐng)自行注意):
1、在項(xiàng)目中添加一Web窗體母版頁(yè)test.Master:右鍵項(xiàng)目—添加—新建項(xiàng)—Web窗體母版頁(yè);
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title></title>
<asp:ContentPlaceHolder ID="head" runat="server">
<form id="form1" runat="server">
<div>
</asp:contentplaceholder>
</div>
</form>
<!--html>
2、在窗體母版頁(yè)test.Master的標(biāo)記之間添加CSS、JS等引用(這里先只添加CSS文件為例):
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title></title>
</asp:contentplaceholder>
3、編輯窗體母版頁(yè)test.Master,添加每個(gè)網(wǎng)頁(yè)的公共內(nèi)容(此處以網(wǎng)頁(yè)布局為上圖的布局為例,三個(gè)div的css樣式就暫不說(shuō)明):
<div id="top"> <%--每個(gè)網(wǎng)頁(yè)的公共樣式:網(wǎng)頁(yè)頭部--%>
<h1>某某某網(wǎng)站</h1>
</div>
<div id="main"> <%--每個(gè)網(wǎng)頁(yè)的不同樣式:網(wǎng)頁(yè)主體內(nèi)容--%>
<%--此處為每個(gè)嵌套此母版的各個(gè)網(wǎng)頁(yè)的不同內(nèi)容--%>
</asp:contentplaceholder>
</div>
<div id="footer"> <%--每個(gè)網(wǎng)頁(yè)的公共樣式:網(wǎng)頁(yè)版權(quán)信息區(qū)--%>
<p>版權(quán)所有:******</p>
</div>
</form>
4、在每個(gè)網(wǎng)頁(yè)中嵌套窗體母版頁(yè)test.Master:右鍵項(xiàng)目—添加—新建項(xiàng)—包含母版頁(yè)的Web窗體test.aspx,在選擇母版頁(yè)對(duì)話框中選擇test.Master,確定,生成的網(wǎng)頁(yè)為:
</asp:content>
</asp:content>
此時(shí)這個(gè)窗體test.aspx和母版頁(yè)test.Master的運(yùn)行效果是一樣的,接下來(lái)就是加上每個(gè)網(wǎng)頁(yè)中的不同的內(nèi)容。
5、此時(shí),網(wǎng)頁(yè)test.aspx中ContentPlaceHolderID=“head”和ContentPlaceHolderID=“contentPlaceHolder”的就相當(dāng)于母版頁(yè)test.Master中對(duì)應(yīng)的。所以假如每個(gè)網(wǎng)頁(yè)都會(huì)有相同部分,就可以把相同部分寫(xiě)在母版頁(yè)的相應(yīng)位置,而將每個(gè)網(wǎng)頁(yè)的不同內(nèi)容寫(xiě)在ContentPlaceHolderID=“contentPlaceHolder”的中。
比如,第4步中,這個(gè)test.aspx已經(jīng)嵌套了這個(gè)樣式,它的主題內(nèi)容為 “ 網(wǎng)站內(nèi)容 網(wǎng)站內(nèi)容 網(wǎng)站內(nèi)容 網(wǎng)站內(nèi)容…… ”,則test.aspx中的代碼為:
</asp:content>
<p>網(wǎng)站內(nèi)容 網(wǎng)站內(nèi)容 網(wǎng)站內(nèi)容 網(wǎng)站內(nèi)容…… </p>
</asp:content>
假如我又建了一個(gè)名為test1.aspx的網(wǎng)頁(yè),除了與test1.aspx中的主體內(nèi)容不一樣之外,其他都一樣,那么就可以讓test1.aspx嵌套母版頁(yè)test.Master,代碼為:
</asp:content>
<p>網(wǎng)站內(nèi)容1 網(wǎng)站內(nèi)容1 網(wǎng)站內(nèi)容1 網(wǎng)站內(nèi)容1…… </p>
</asp:content>
拓展:母版頁(yè)嵌套母版頁(yè)
當(dāng)整個(gè)網(wǎng)站內(nèi)的所有網(wǎng)頁(yè)并不是這一種樣式,而是一個(gè)大的網(wǎng)站分為幾個(gè)欄目,每個(gè)欄目中網(wǎng)頁(yè)的風(fēng)格樣式統(tǒng)一,這時(shí)候可以用母版頁(yè)來(lái)嵌套母版頁(yè) :
現(xiàn)在再建立一個(gè)母版頁(yè)(我在這里給它取名為“子母版頁(yè)”),用它來(lái)嵌套上面的母版頁(yè)test.Master,代碼為:
</asp:content>
<%--此處為嵌套“子母版頁(yè)”的各個(gè)網(wǎng)頁(yè)的不同內(nèi)容--%>
</asp:contentplaceholder>
</asp:content>
注意,代碼第一行的MasterPageFile=“~/test.Master”即要嵌套的母版頁(yè)的地址,“~”為當(dāng)前目錄。
嵌套網(wǎng)頁(yè)母版項(xiàng)的好處:
可以利用VisualStudio中的窗體母版頁(yè)來(lái)將每個(gè)頁(yè)面中相同的部分進(jìn)行封裝,在創(chuàng)建相同結(jié)構(gòu)的網(wǎng)頁(yè)時(shí),便可以直接嵌套這個(gè)窗體母版頁(yè),避免了代碼的重復(fù),提高了代碼的復(fù)用性;另外,如果要修改一個(gè)欄目甚至整個(gè)網(wǎng)站的風(fēng)格,則只需修改母版頁(yè)以及母版頁(yè)中引入的<script>等文件,提高了代碼的可維護(hù)性,充分體現(xiàn)了OOP的思想。
希望本文所述對(duì)大家的asp.net程序設(shè)計(jì)有所幫助。
- 詳解Asp.Net母版頁(yè)元素ID不一致的體現(xiàn)
- Asp.Net套用母版頁(yè)后元素ID不一致(個(gè)人總結(jié))
- 淺談Asp.Net母版頁(yè)和內(nèi)容頁(yè)運(yùn)行機(jī)制
- 淺談Asp.Net母版頁(yè)的相關(guān)知識(shí)
- 在ASP.NET 2.0中操作數(shù)據(jù)之三:創(chuàng)建母版頁(yè)和站點(diǎn)導(dǎo)航
- asp.net母版頁(yè)如何使用
- ASP.NET母版頁(yè)基礎(chǔ)知識(shí)介紹
- ASP.NET中母版頁(yè)和shtml實(shí)例入門
- asp.net使用母版頁(yè)中使用ajax腳本取數(shù)據(jù)
- ASP.NET下母版頁(yè)和內(nèi)容頁(yè)中的事件發(fā)生順序整理
- ASP.NET 2.0 中的創(chuàng)建母版頁(yè)
- ASP.NET MVC使用母版頁(yè)視圖
相關(guān)文章
限制CheckBoxList控件只能單選實(shí)現(xiàn)代碼及演示動(dòng)畫(huà)
開(kāi)發(fā)要求,原本對(duì)CheckBoxList控件是用來(lái)讓用戶多選的。但現(xiàn)在特殊要求,這個(gè)CheckBoxList控件限制只能單選,很多新手朋友可能不知從何下手,為此本文的出現(xiàn)時(shí)有必要的了,有需要的朋友可以了解此文2013-01-01asp.net使用LINQ to SQL連接數(shù)據(jù)庫(kù)及SQL操作語(yǔ)句用法分析
這篇文章主要介紹了asp.net使用LINQ to SQL連接數(shù)據(jù)庫(kù)及SQL操作語(yǔ)句用法,較為詳細(xì)的分析了LINQ操作sql語(yǔ)句的功能、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-05-05asp.net實(shí)現(xiàn)固定GridView標(biāo)題欄的方法(凍結(jié)列功能)
這篇文章主要介紹了asp.net實(shí)現(xiàn)固定GridView標(biāo)題欄的方法,即凍結(jié)列功能,涉及GridView結(jié)合前端js操作數(shù)據(jù)顯示的相關(guān)技巧,需要的朋友可以參考下2016-06-06使用updatepanel局部刷新實(shí)現(xiàn)注冊(cè)時(shí)對(duì)用戶名的檢測(cè)示例
這篇文章主要介紹了使用updatepanel局部刷新實(shí)現(xiàn)注冊(cè)時(shí)對(duì)用戶名的檢測(cè)示例,需要的朋友可以參考下2014-03-03ASP.NET Core擴(kuò)展庫(kù)之Http日志的使用詳解
這篇文章主要介紹了ASP.NET Core擴(kuò)展庫(kù)之Http日志的使用詳解,幫助大家更好的理解和學(xué)習(xí)使用.net技術(shù),感興趣的朋友可以了解下2021-04-04作業(yè)調(diào)度框架Quartz.net用法詳解
本文詳細(xì)講解了作業(yè)調(diào)度框架Quartz.net的用法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06ajax.net +jquery 無(wú)刷新三級(jí)聯(lián)動(dòng)的實(shí)例代碼
ajax.net +jquery 無(wú)刷新三級(jí)聯(lián)動(dòng)的實(shí)例代碼,需要的朋友可以參考一下2013-05-05