思路
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文件。程序使用了是循環替換,因此對需替換大量元素的模板速度非常快。