当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 利用ASP.NET技术动态生成HTML页面

ASP.NET
在C#中导入WebBrowser控件,生成具有强名称的程序集
Asp.Net中的脚本回调和Server.Transfer页面传值
暂时性的解决datagrid控件数据绑定时候xxx字段不属于xxx表的错误
http://www.donews.net/yangwl/archive/2004/10/17/136872.aspx
Some tips for using visual studio .net
Grasshopper简介(节选)
ORACLE 常用的SQL语法和数据对象
[DNN学习所得]让IE也能实现解压缩功能(提供演示源码下载)
学习笔记之Microsoft Windows服务
关于XML:以对象模型为中心
P&P Enterprise Library Extensions
简易的字符替换,可以用于用户自我介绍输入框,简单新闻回复& etc.
缩略图多路径多格式保存
"关机/休眠/重启/注销"的类
[DNN功能]自己动手做语言包
处理WinForm多线程程序时的陷阱
获得光标在多行textbox中的行与列的函数
ADO.NET 和 ADO 的比较
vb.net类的封装,继承,多态,抽象之一
Display XML in AxSHDocVw.AxWebBrowser

利用ASP.NET技术动态生成HTML页面


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 143 ::
收藏到网摘: n/a

思路

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>www.knowsky.com</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">
<spanstyle="color:$htmlformat[1];font-size:$htmlformat[2]">$htmlformat[3]</span>
</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[i]);
}

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

try
{
 using(StreamWritersw=newStreamWriter("存放路径和页面名",false,System.Text.Encoding.GetEncoding("GB2312")))
{
 sw.WriteLine(htmltext);
 sw.Flush();
 sw.Close();
}

}

catch

{

Response.Write("Thefilecouldnotbewirte:");

}

小结

用此方法可以方便的生成html文件。程序使用了是循环替换,因此对需替换大量元素的模板速度非常快。