Asp.net动态生成html页面

来源:互联网 发布:ubuntu 16.04 ssd 编辑:程序博客网 时间:2024/06/17 12:13

此功能适用于后台数据库功能不强的web站点,即大部分文本不是存放在数据库的记录中,而是放在html文件或者xml文件中,仅仅把索引放到数据库中,如文章标题、类别、查询关键字等。这样适合于后台没有诸如mssqlserver这样的数据库支持的web站点。
适用于新闻发布系统,比如sina、163等都是采用动态生成html页面的。
适用于需动态定制页面的程序。比如论坛、聊天室等。可以加载定制好的html页面,来加强美观。
思路
1.利用如dw-mx这样的工具生成html格式的模板,在需要添加格式的地方加入特殊标记(如$htmlformat$),动态生成文件时利用代码读取此模板,然后获得前台输入的内容,添加到此模板的标记位置中,生成新文件名后写入磁盘,写入后再向数据库中写入相关数据。
2.使用后台代码硬编码html文件,可以使用htmltextwriter类来写html文件。
优点
1.可以建立非常复杂的页面,利用包含js文件的方法,在js文件内加入document.write()方法可以在所有页面内加入如页面头,广告等内容。
2.静态html文件利用mswindows2000的indexserver可以建立全文搜索引擎,利用asp.net可以以datatable的方式得到搜索结果。而win2000的index服务无法查找xml文件的内容。如果包括了数据库搜索与index索引双重查找,那么此搜索功能将非常强大。
3.节省服务器的负荷,请求一个静态的html文件比一个aspx文件服务器资源节省许多。
缺点
思路二:如果用硬编码的方式,工作量非常大,需要非常多的html代码。调试困难。而且使用硬编码生成的html样式无法修改,如果网站更换样式,那么必须得重新编码,给后期带来巨大的工作量。
因此这里采用的是第一种思路
示列代码
1.定义(template.htm)html模板页面
<html>
<head>
<title></title>
<metahttp-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:1pxsolid#000000">
<tr>
<tdwidth="100%"valign="middle"align="left">
$htmlformat[3]
</td>
</tr>
</table>
</body>
</html>
2.asp.net代码:
//---------------------读html模板页面到stringbuilder对象里----
string[]format=newstring[4];//定义和htmlyem标记数目一致的数组
stringbuilderhtmltext=newstringbuilder();
try
{
using(streamreadersr=newstreamreader("存放模板页面的路径和页面名"))
{
stringline;
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(inti=0;i<4;i++)
{
htmltext.replace("$htmlformat["+i+"]",format);
}
//----------生成htm文件------------------╠╠
try
{
using(streamwritersw=newstreamwriter("存放路径和页面名",false,system.text.encoding.getencoding("gb2312")))
{
sw.writeline(htmltext);
sw.flush();
sw.close();
}
}
catch
{
response.write("thefilecouldnotbewirte:");
}
小结
用此方法可以方便的生成html文件。程序使用了是循环替换,因此对需替换大量元素的模板速度非常快。
本贴来自天极网群乐社区--http://q.yesky.com/group/review-18142333.html

 

原创粉丝点击