Asp.net动态生成html页面
1.新闻测试2.新闻测试3.新闻测试4.新闻测试上一页12345下一页像上面那样的效果.net通过加载模版生成HTML页面这个分页该怎么写...
1.新闻测试
2.新闻测试
3.新闻测试
4.新闻测试
上一页 1 2 3 4 5 下一页
像上面那样的效果 .net 通过加载模版 生成HTML页面 这个分页该怎么写 展开
2.新闻测试
3.新闻测试
4.新闻测试
上一页 1 2 3 4 5 下一页
像上面那样的效果 .net 通过加载模版 生成HTML页面 这个分页该怎么写 展开
4个回答
展开全部
思路一:
<!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>
思路二:
如果用硬编码的方式,工作量非常大,需要非常多的html代码。调试困难。而且使用硬编码生成的html样式无法修改,如果网站更换样式,那么必须得重新编码,给后期带来巨大的工作量。
<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>
<!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>
思路二:
如果用硬编码的方式,工作量非常大,需要非常多的html代码。调试困难。而且使用硬编码生成的html样式无法修改,如果网站更换样式,那么必须得重新编码,给后期带来巨大的工作量。
<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>
展开全部
using System.Web.UI.HtmlControls;
//pageCount,一共要分多少页
public void PaintPage(int pageCount)
{
//生成“上一页”
HtmlGenericControl previousPage = new HtmlGenericControl("a");
previoutPage.InnerText="上一页";
//下面的代码循环生成1,2,3,4,5....
HtmlGenericControl ul = new HtmlGenericControl("ul");
ul.Attributes.Add("list-style-type", "none");
HtmlGenericControl li = null;
for (int i = 1; i <= pageCount; i++)
{
li = new HtmlGenericControl("li");
li.InnerHtml = string.Format("<a href='{0}?pageIndex={1}'>{1}</a>", Page.Request.Url, i);
ul.Controls.Add(li);
}
//生成“下一页”
HtmlGenericControl nextPage = new HtmlGenericControl("a");
nextPage .InnerText="下一页";
//panel只是一个容器。我用的是placeHolder
panel.Controls.Add(previousPage);
panel.Controls.Add(ul);
panel.Controls.Add(nextPage);
}
这样基本就写完了,不过样式是不对的,要去掉li元素的“·”,还要把li元素横向显示。
上一页,下一页,里面还是有一些逻辑的,要不然也不能真的实现,上一页,下一页。
不过你要的显示的样式,基本实现了。
//pageCount,一共要分多少页
public void PaintPage(int pageCount)
{
//生成“上一页”
HtmlGenericControl previousPage = new HtmlGenericControl("a");
previoutPage.InnerText="上一页";
//下面的代码循环生成1,2,3,4,5....
HtmlGenericControl ul = new HtmlGenericControl("ul");
ul.Attributes.Add("list-style-type", "none");
HtmlGenericControl li = null;
for (int i = 1; i <= pageCount; i++)
{
li = new HtmlGenericControl("li");
li.InnerHtml = string.Format("<a href='{0}?pageIndex={1}'>{1}</a>", Page.Request.Url, i);
ul.Controls.Add(li);
}
//生成“下一页”
HtmlGenericControl nextPage = new HtmlGenericControl("a");
nextPage .InnerText="下一页";
//panel只是一个容器。我用的是placeHolder
panel.Controls.Add(previousPage);
panel.Controls.Add(ul);
panel.Controls.Add(nextPage);
}
这样基本就写完了,不过样式是不对的,要去掉li元素的“·”,还要把li元素横向显示。
上一页,下一页,里面还是有一些逻辑的,要不然也不能真的实现,上一页,下一页。
不过你要的显示的样式,基本实现了。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
把总页数当前页知道以后,今天判断循环就可以了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询