所以,梦想着那么大段的程序代码变成几个简单的字符代替,这样只要设计好页面把该功能插入就OK了。其实这也简单,只需将实现该功能的程序代码做成子程序,然后主页调用就可以了。
很多时候,在博客中国,你会选择到很多的模板,甚至有可能自己来设计;或者采用猪飞飞BLOG的各大站长都将其站点改得不近相同……这些,我们都归功于ASP采用模板的功能。
那下面偶就借花献佛,将模板拿来分析,以馈各位朋友。
首先,模板需要在线修改,则应采用数据库保存模板代码
所谓的模板,就是设计完工的标准的HTML代码,其中需要由程序实现的功能部分将采用特殊字符串代替。然,这些特殊字符串需要在显示的时候被编译为对应的功能。
1,设计数据库testmb.mdb
新建表moban:字段m_id(自动编号,主关键字);字段m_html(备注类型)
2,假设第一模板内容代码
将下列代码拷贝到m_html字段中
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>testmb</title>
</head>
<body leftmargin="0" topmargin="0">
<table width="100%" height="100%" border="0" cellpadding="5" cellspacing="2">
<tr align="right" bgcolor="#CCCCCC">
<td height="20" colspan="2">$cntop$</td>
</tr>
<tr valign="top">
<td width="25%" bgcolor="#e5e5e5">$cnleft$</td>
<td width="74%" bgcolor="#f3f3f3">$cnright$</td>
</tr>
</table>
</body>
</html>
注意$cntop$、$cnleft$、$cnright$,它们将要实现某些具体的程序功能
3,建立数据库连接文件conn.asp
<%
set conn= Server.CreateObject("ADODB.Connection")
connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Server.MapPath("testmb.mdb")
conn.Open connstr
%>
4,建立特殊字符串转换所需要的库文件lib.asp
该文件的主要作用是将实现某些功能的ASP程序做成字程序,以方便调用。
<%
dim topcode
sub cntop()
topcode="现在时间是:"
topcode=topcode&now()
end sub
dim leftcode,i
sub cnleft()
for i = 1 to 5
leftcode=leftcode&"<p>cnbruce.com"
next
end sub
dim rightcode
sub cnright()
for i = 1 to 9
rightcode=rightcode&"<hr color="&i&i&i&i&i&i&">"
next
end sub
%>
5,最后,调用数据库中的模板代码,将特殊字符串转换。
<!--#include file="conn.asp" -->
<!--#include file="lib.asp" -->
<%
sql="select * from moban where m_id=1"
set rs=Server.CreateObject("adodb.recordset")
rs.open sql,conn,1,1
mb_code=rs("m_html")
rs.close
set rs=nothing
cntop()
mb_code=replace(mb_code,"$cntop$",topcode)
cnleft()
mb_code=replace(mb_code,"$cnleft$",leftcode)
cnright()
mb_code=replace(mb_code,"$cnright$",rightcode)
response.write mb_code
%>
该页主要作用是将模板代码进行显示,并将其中的特殊代码转变为相对应子程序功能。
至此,ASP的模板功能基本完成,剩下的就是:建立具备编辑模板功能的程序页面,将库文件改变为自己所需要程序功能……
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=783511
ASP.NET中应用模板采用
1。用户界面
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
using System.Text;
namespace localhost.模版后台管理
{
/// <summary>
/// UseInterface 的摘要说明。
/// </summary>
public class UseInterface : System.Web.UI.Page
{
protected string show_string;
protected StringBuilder show_string2;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
SqlConnection Conn;
Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
Conn.Open();
SqlDataAdapter da=new SqlDataAdapter("select Skin_html from SkinBin where IsDefault=1",Conn);
DataSet ds=new DataSet();
da.Fill(ds,"skin");
// show_string2.Append(ds.Tables["skin"].Rows[0][0].ToString());
// show_string2.Replace("$show_blogname$","无影杀手");//替换特殊标记
show_string=ds.Tables["skin"].Rows[0][0].ToString();
show_string=show_string.Replace("$show_blogname$","无影杀手");
Response.Write(show_string);
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
}
}
2。管理后台
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
namespace localhost.模版后台管理
{
/// <summary>
/// SkinManage 的摘要说明。
/// </summary>
public class SkinManage : System.Web.UI.Page
{
protected System.Web.UI.WebControls.DataGrid DataGrid2;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
// 在此处放置用户代码以初始化页面
SqlConnection Conn;
Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
Conn.Open();
SqlDataAdapter da=new SqlDataAdapter("select Id,Skin_name from SkinBin",Conn);
DataSet ds=new DataSet();
da.Fill(ds,"skin");
da.Fill(ds,"skinall");
// show_string=ds.Tables["skin"].Rows[0][0].ToString();
DataGrid2.DataSource=ds.Tables["skinall"].DefaultView;
DataGrid2.DataBind();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.DataGrid2.DeleteCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.DataGrid2_DeleteCommand);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void DataGrid2_DeleteCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
{
try
{
SqlConnection Conn;
Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
Conn.Open();
string Id="";
Id=e.Item.Cells[2].Text;
SqlCommand Comm=new SqlCommand("update SkinBin set IsDefault=1 where Id="+Id,Conn);
Comm.ExecuteNonQuery();
}
catch
{
}
Response.Write("<script>alert('模版已更改,请查看用户界面');</script>");
}
}
}
3。数据库
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[SkinBin]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[SkinBin]
GO
CREATE TABLE [dbo].[SkinBin] (
[Id] [int] IDENTITY (1, 1) NOT NULL ,
[Skin_name] [char] (10) COLLATE Chinese_PRC_CI_AS NULL ,
[Skin_html] [ntext] COLLATE Chinese_PRC_CI_AS NULL ,
[IsDefault] [bit] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=668003