此功能适用于后台数据库功能不强的web站点,即大部分文本不是存放在数据库的记录中,而是放在html文件或者xml文件中,仅仅把索引放到数据库中,如文章标题、类别、查询关键字等。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>无标题文档</title>
</head>
<body>
此功能适用于后台数据库功能不强的web站点,即大部分文本不是存放在数据库的记录中,而是放在html文件或者xml文件中,仅仅把索引放到数据库中,如文章标题、类别、查询关键字等。这样适合于后台没有诸如MS
Sql Server这样的数据库支持的Web站点。
<p>适用于新闻发布系统,比如sina、163等都是采用动态生成html页面的。</p>
<p>适用于需动态定制页面的程序。比如论坛、聊天室等。可以加载定制好的html页面,来加强美观。</p>
<p>思路</p>
<p>1. 利用如Dw-Mx这样的工具生成html格式的模板,在需要添加格式的地方加入特殊标记(如$htmlformat$),动态生成文件时利用代码读取此模板,然后获得前台输入的内容,添加到此模板的标记位置中,生成新文件名后写入磁盘,写入后再向数据库中写入相关数据。</p>
<p>2. 使用后台代码硬编码Html文件,可以使用HtmlTextWriter类来写html文件。</p>
<p>优点</p>
<p>1. 可以建立非常复杂的页面,利用包含js文件的方法,在js文件内加入document.write()方法可以在所有页面内加入如页面头,广告等内容。</p>
<p>2. 静态html文件利用MS Windows2000的Index Server可以建立全文搜索引擎,利用asp.net可以以DataTable的方式得到搜索结果。而Win2000的Index服务无法查找xml文件的内容。如果包括了数据库搜索与Index索引双重查找,那么此搜索功能将非常强大。</p>
<p>3. 节省服务器的负荷,请求一个静态的html文件比一个aspx文件服务器资源节省许多。</p>
<p>缺点</p>
<p>思路二: 如果用硬编码的方式,工作量非常大,需要非常多的html代码。调试困难。而且使用硬编码生成的html样式无法修改,如果网站更换样式,那么必须得重新编码,给后期带来巨大的工作量。</p>
<p>因此这里采用的是第一种思路</p>
<p>示列代码</p>
<p>1.定义(template.htm)html模板页面</p>
<p> <html></p>
<p> <head></p>
<p> <title></title></p>
<p> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"></p>
<p> </head></p>
<p> <body ></p>
<p> <table $htmlformat[0] height="100%" border="0" width="100%"
cellpadding="10" cellspacing="0" bgcolor="#eeeeee"
style="border:1px solid #000000"></p>
<p> <tr></p>
<p> <td width="100%" valign="middle" align="left"></p>
<p> <span style="color: $htmlformat[1];font-size: $htmlformat[2]">$htmlformat[3]</span></p>
<p> </td></p>
<p> </tr></p>
<p> </table></p>
<p> </body></p>
<p></html></p>
<p>2.asp.net代码:</p>
<p> //---------------------读html模板页面到stringbuilder对象里----</p>
<p> string[] format=new string[4];//定义和htmlyem标记数目一致的数组</p>
<p> StringBuilder htmltext=new StringBuilder();</p>
<p> try </p>
<p> {</p>
<p> using (StreamReader sr = new StreamReader("存放模板页面的路径和页面名")) </p>
<p> {</p>
<p> String line;</p>
<p> while ((line = sr.ReadLine()) != null) </p>
<p> {</p>
<p> htmltext.Append(line);</p>
<p> }</p>
<p> sr.Close();</p>
<p> }</p>
<p> }</p>
<p> catch </p>
<p> {</p>
<p> Response.Write("<Script>alert('读取文件错误')</Script>");</p>
<p> }</p>
<p>//---------------------给标记数组赋值------------</p>
<p> format[0]="background=""bg.jpg""";//背景图片</p>
<p>format[1]="#990099";//字体颜色</p>
<p>format[2]="150px";//字体大小</p>
<p>format[3]= "<marquee>生成的模板html页面</marquee>";//文字说明</p>
<p>//----------替换htm里的标记为你想加的内容</p>
<p>for(int i=0;i<4;i++)</p>
<p> {</p>
<p> htmltext.Replace("$htmlformat["+i+"]",format[i]);</p>
<p>}</p>
<p>//----------生成htm文件------------------――</p>
<p>try</p>
<p> {</p>
<p> using(StreamWriter sw=new StreamWriter("存放路径和页面名",false,System.Text.Encoding.GetEncoding("GB2312")))</p>
<p> {</p>
<p> sw.WriteLine(htmltext);</p>
<p> sw.Flush();</p>
<p> sw.Close();</p>
<p> }</p>
<p> }</p>
<p> catch</p>
<p> { </p>
<p> Response.Write ("The file could not be wirte:");</p>
<p> }</p>
<p>小结</p>
<p>用此方法可以方便的生成html文件。程序使用了是循环替换,因此对需替换大量元素的模板速度非常快。</p>
<p></p>
</body>
</html>