首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络编程-> ASP教程
ASP网页模板的应用: 让程序和界面分离,让ASP脚本更清晰,更换界面更容易-ASP教程,ASP应用
作者:网友供稿 点击:5
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
为了避免asp程序和html代码混写造成维护困难的情况,本文介绍了一种方法,利用模板来分离程序和页面,使程序设计更加轻松。

在使用asp制作一个站点的时候,常常会出现一个asp文件中,程序代码和html代码混合的情况。这样子做有许多缺点:
1. 且不说编程时就要对页面布局进行设计和编排,造成代码混乱难懂,不规范;
2. 当需要改变页面外观时,你不仅要改变html部份,也需要改变asp代码,不易维护。

那么,要如何才能避免这些麻烦呢?
答案就是使用模板文件,将asp代码和html页面分开,一切问题就都解决了。使用模板有以下好处:
1. 在很短的时间内可以替换整个站点的外观;
2. 使程序员可以抽象编程,而无须接触html代码;
3. 可以重复利用以前的模板。


使用过php的程序就会知道,php有个模板程序(fasttemplate),现在的问题是如何在asp中实现类似的功能。
microsoft的asp带有两种脚本:vbscript和jscript。它们都带有一个 "正则表达式对象" (regexp),利用字符串对象和regexp对象,就可以轻松的实现模板功能。沐枫以此编写了一个 "template.jscript.inc" 文件,此文件的内容附在文章后面。有能力的读者可以根据自己的需要进行改进。

下面介绍一下使用方法。由于此文件是使用jscript编写的(当然要转成vbscript也很容易),因此,缺省脚本语言要设为jscript,即asp程序第一行应为:<%@language=jscript%>,然后再包含模板程序文件:<!--#include file="template.jscript.inc"-->。

先介绍一下template类的使用:
1. 建立template对象:template(path)
参数:path(字符串类型) html模板文件的存放路径。
使用new 操作符建立template对象。

例子:
var tpl = new template("c:\\template");

在程序中可以用tpl.tplpath来取得模板路径,也可以通过tpl.tplpath来改变模板路径。
如:
tpl.tplpath = "d:\\template";

2. 装载模板文件:template.load(name, file)
参数:name(字符串类型) 是一个模板变量名。
file(字符串类型) 模板文件名。此文件存放在html模板路径下。
读取文件file到模板变量name中。

例子:
tpl.load("main", "test.htm");

此时,模板变量main就包含了文件test.htm的内容。
你可以用tpl.main来访问模板变量"main"。

例子:
<%=tpl.main%>
将显示刚才读进来的test.htm文件内容。

3. 模板分拆:template.split(name)
参数:name(字符串类型) 是一个模板变量名。
将name中的子模板分解。

例子:
先假设上例中的test.htm内容为:
-------------------
这是主模板。接下来是:<!--#tpldef sub-->sub子模板,还有
<!--#tpldef third-->third模板。<!--#tplend third-->
<!--#tplend sub-->
-------------------
那么:
tpl.split("main");
执行以后,就会生成新的模板变量"sub",和"third",它们的内容就是<!--#tpldef sub-->和<!--#tplend sub-->之间语句。
而且"main"模板变量的内容也会发生改变:

tpl.main 的内容为:"这是主模板。接下来是{sub}"
tpl.sub 的内容为:"sub子模板,还有{third}"
tpl.third 的内容为:"third模板。"

tpldef 和 tplend 定义的语句块充许多重嵌套。

4. 模板处理:template.parse(name)
参数:name(字符串类型) 是一个模板变量。
将模板中用花括号括起来的字串用同名的模板变量的内容替换。

例子:续上例
<%=tpl.parse("main")%>
显示:"这是主模板。接下来是sub子模板,还有{third}"

由例子可知,parse只替换"main"模板中的{sub}变量,而不能嵌套替换下去。这是为了增加程序灵活性而故意设计的。那么该怎么样完整显示"main"模板呢?

例子:
tpl.sub = tpl.parse("sub"); //先处理sub变量,再处理main变量。
response.write(tpl.parse("main"));

5. 自定义模板变量。
自定义模板变量很简单,可以直接用赋值语句来定义和修改任何变量:

例子:
tpl.hahaha = "这是自定义变量";
tpl.third = "改变原模板中的third变量";

需要注意的是,由于jscrip是区分大小写的,因此一定要注意大小写的拼写。一般来说,html模板中定义的模板变量都用大写。

另外,模板中使用的"tplpath","load","parse","split"变量是内部使用的,不要挪做它用,否则程序将可能发生异常。

下面举个完整的例子:

第一步:先建立html模板文件。

这里先说明html模板文件的组成。首先,它和普通的html文件几乎没有区别,只不过多了几个标记。
模板的标记有两种。让我们先看一个例子:

test.htm
-----------------
<!--文件名:test.htm-->
<html>
<title>范例</title>
<header>
</header>
<body>
这是一个表格范例。
<table>
<!--#tpldef maxx-->10<!--#tplend maxx-->
<!--...注意,此处使用了一个技巧即定义了maxx模板变量并赋值为10。-->
<tr>
<td>x</td><td>x的平方</td>
</tr>
<!--#tpldef row-->
<tr>
<td>{x}</td><td>{xx}</td>
</tr>
<!--#tplend row-->
</table>
以上共有{count}行数据。
</body>
</html>
-----------------

从上面可以看出,象{x},{xx},{count}之类的记号是定义模板变量。它们将会在asp程序中被替代。
而<!--#tpldef row-->...<!--#tplend row-->是定义一个语句块"row"。在asp程序中就可以将"row"块重复多次。

第二步:设计asp程序。

test.asp
-------------------
<%@language=jscript%>
<!--#include file="template.jscript.inc"-->
<%
var tpl = new template("c:\\inetpub\\wwwroot");
var str="";
var i;

tpl.load("main","test.htm");
tpl.split("main");

tpl.count = 0;

for(i=1;i<=tpl.maxx;i++) //tpl.maxx在模板中定义为10。
{
tpl.x = i;
tpl.xx = i*i;
str+=tpl.parse("row");
tpl.count++;
}
tpl.row = str;
tpl.maxx =""; //清空此模板变量,以避免被显示出来。
%>
<%=tpl.parse("main")%>
-------------------
上面的程序将显示一个1到10的平方表。

通常在使用模板的情况下,都只要在最后一行加上显示页面的语句。因此整个程序显得十分清晰。此时,只要对模板文件进行编辑,就可以改变整个页面的外观。
至于模板文件,它可以是任何文件,如html文件、asp文件,甚至是程序本身!,而且在一个程序中可以装载多个模板配合使用,这样,不仅具有极大灵活性,而且模板文件与asp程序的相关性可减到最低程度。
好好利用模板,将会使你的工作更加轻松。


附:template 源程序
------------------------------------
<!--文件名:template.jscript.inc-->
<%
/*********************************************************/
/* template class */
/* author: 沐枫 (lin.y@263.net) */
/* date: 2000-6-09 */
/*********************************************************/

//template method define

function template_parse(name)
{
if(this[name]==null)
return "";

var reg = new regexp("{(\\w*)}","ig");
var str = new string(this[name]);
var arr = str.match(reg);
var i;

if(arr != null)
for(i=0;i<arr.length;i++)
{
key = arr[i].slice(1,-1);
reg = new regexp(arr[i],"ig");
if(this[key]!=null)
str = str.replace(reg,this[key]);
}
return str;
}

function template_split(name)
{
var len = 0;
var arr;

if(this[name]==null)
return;

var template_exp = new regexp("<!--#tpldef +(\\w*) *-->((.|\\n)*)<!--#tplend +\\1 *-->","i");
while(this[name].search(template_exp)!=-1)
{
arr = this[name].match(template_exp);

this[arr[1]] = arr[2];
this[name] = this[name].replace(template_exp,"{"+arr[1]+"}");
this.split(arr[1]);
}
}

function template_load(name,filename)
{
var fso = new activexobject("scripting.filesystemobject");
var file = fso.buildpath(this.tplpath, filename);
if(fso.fileexists(file))
{
var f = fso.opentextfile(file, 1);
this[name] = f.readall();
}
}


//template constructor

function template(path)
{
//property
this.tplpath = path;

//method
this.parse = template_parse;
this.split = template_split;
this.load = template_load;
}
%>

文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·在ASP.NET中使用Office Web Components (OWC)创建统计图-.NET教程,数据库应用
·windows系统下jsp+mysql+tomcat的配置-JSP教程,Application/Applet
·把aspx文件编译成DLL文件-.NET教程,Asp.Net开发
·Haneng.com的简单留言板制作源程序例子-ASP教程,ASP应用
·使用VB实现邮箱自动注册(一):表单自动提交-.NET教程,VB.Net语言
·VS.NET安装指南(To菜鸟)-.NET教程,Asp.Net开发
·web下水晶报表的使用!-.NET教程,Web Service开发
·C# 静态成员和方法的学习小结-.NET教程,数据库应用
·IIS的使用-ASP教程,ASP基础
·asp讲座之二:读取通过表单发送的数据
最新文章
·photoshop鼠绘实例:浪漫夏夜壁纸_photoshop教程
·买卖中小网站交易的一些细节问题_站长心得
·七招打造最安全的windows xp操作系统_windows xp
·做google adsense最佳和最重要的要诀_网赚技巧
·上下文关联广告清单(内文广告)推荐_网赚技巧
·广告联盟,痛定思痛_网赚技巧
·insenz首批广告费发放给站长_网赚技巧
·李彦宏:三分之一时间用在寻找人才_站长访谈
·中国汽车资源网杨锁民:网络寒冬时下海_站长访谈
·做it新闻资讯网站应先学新浪_站长心得
相关主题
  • asp网页提升速度方法5则_asp技巧
  • ASP网页访问权的控制-ASP教程,ASP应用
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭