DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> XML學習教程 >> XML詳解 >> asp.net生成HTML
asp.net生成HTML
編輯:XML詳解     
思路

1. 利用如Dw-Mx這樣的工具生成html格式的模板,在需要添加格式的地方加入特殊標記(如$Htmlformat$),動態生成文件時利用代碼讀取此模板,然後獲得前台輸入的內容,添加到此模板的標記位置中,生成新文件名後寫入磁盤,寫入後再向數據庫中寫入相關數據。

2. 使用後台代碼硬編碼Html文件,可以使用HtmlTextWriter類來寫Html文件。

優點

1. 可以建立非常復雜的頁面,利用包含js文件的方法,在JS文件內加入document.write()方法可以在所有頁面內加入如頁面頭,廣告等內容。

2. 靜態Html文件利用MS Windows2000的Index Server可以建立全文搜索引擎,利用ASP.Net可以以DataTable的方式得到搜索結果。而Win2000的Index服務無法查找XML文件的內容。如果包括了數據庫搜索與Index索引雙重查找,那麼此搜索功能將非常強大。

3. 節省服務器的負荷,請求一個靜態的Html文件比一個ASPx文件服務器資源節省許多。

缺點

思路二: 如果用硬編碼的方式,工作量非常大,需要非常多的html代碼。調試困難。而且使用硬編碼生成的Html樣式無法改,如果網更換樣式,那麼必須得重新編碼,給後期帶來巨大的工作量。

因此這裡采用的是第一種思路

示列代碼

1.定義(template.htm)Html模板頁面

<Html>

<head>

<title></title>

<meta http-equiv="Content-Type" content="text/Html; charset=gb2312">

</head>

<body >

<table $Htmlformat[0] height="100%" border="0" width="100%" cellpadding="10" cellspacing="0" bgcolor="#eeeeee" style="border:1px solid #000000">

<tr>

<td width="100%" valign="middle" align="left">

<span style="color: $htmlformat[1];font-size: $htmlformat[2]">$Htmlformat[3]</span>

</td>

</tr>

</table>

</body>

</Html>

2.ASP.Net代碼:

//---------------------讀Html模板頁面到stringbuilder對象裡----
string[] format=new string[4];//定義和Htmlyem標記數目一致的數組

StringBuilder Htmltext=new StringBuilder();

try

{

using (StreamReader sr = new StreamReader("存放模板頁面的路徑和頁面名"))

{

String line;

while ((line = sr.ReadLine()) != null)

{

Htmltext.Append(line);

}

sr.Close();


}

}

catch

{

Response.Write("<Script>alert('讀取文件錯誤')</Script>");

}

//---------------------給標記數組賦值------------

format[0]="background=\"bg.jpg\"";//背景圖片

format[1]= "#990099";//字體顏色

format[2]="150px";//字體大小

format[3]= "<marquee>生成的模板Html頁面</marquee>";//文字說明

//----------替換htm裡的標記為你想加的內容

for(int i=0;i<4;i++)

{

htmltext.Replace("$Htmlformat["+i+"]",format[i]);

}

//----------生成htm文件------------------――

try

{

using(StreamWriter sw=new StreamWriter("存放路徑和頁面名",false,System.Text.Encoding.GetEncoding("GB2312")))

{

sw.WriteLine(Htmltext);

sw.Flush();

sw.Close();

}

}

catch

{

Response.Write ("The file could not be wirte:");

}

小結

用此方法可以方便的生成Html文件。程序使用了是循環替換,因此對需替換大量元素的模板速度非常快。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved