為了避免asp程序和html代碼混寫造成維護(hù)困難的情況,本文介紹了一種方法,利用模板來分離程序和頁面,使程序設(shè)計(jì)更加輕松。
在使用asp制作一個站點(diǎn)的時候,常常會出現(xiàn)一個asp文件中,程序代碼和html代碼混合的情況。這樣子做有許多缺點(diǎn):
1. 且不說編程時就要對頁面布局進(jìn)行設(shè)計(jì)和編排,造成代碼混亂難懂,不規(guī)范;
2. 當(dāng)需要改變頁面外觀時,你不僅要改變html部份,也需要改變asp代碼,不易維護(hù)。
那么,要如何才能避免這些麻煩呢?
答案就是使用模板文件,將asp代碼和html頁面分開,一切問題就都解決了。使用模板有以下好處:
1. 在很短的時間內(nèi)可以替換整個站點(diǎn)的外觀;
2. 使程序員可以抽象編程,而無須接觸html代碼;
3. 可以重復(fù)利用以前的模板。
使用過php的程序就會知道,php有個模板程序(fasttemplate),現(xiàn)在的問題是如何在asp中實(shí)現(xiàn)類似的功能。
microsoft的asp帶有兩種腳本:vbscript和jscript。它們都帶有一個 "正則表達(dá)式對象" (regexp),利用字符串對象和regexp對象,就可以輕松的實(shí)現(xiàn)模板功能。沐楓以此編寫了一個 "template.jscript.inc" 文件,此文件的內(nèi)容附在文章后面。有能力的讀者可以根據(jù)自己的需要進(jìn)行改進(jìn)。
下面介紹一下使用方法。由于此文件是使用jscript編寫的(當(dāng)然要轉(zhuǎn)成vbscript也很容易),因此,缺省腳本語言要設(shè)為jscript,即asp程序第一行應(yīng)為:<%@language=jscript%>,然后再包含模板程序文件:。
先介紹一下template類的使用:
1. 建立template對象:template(path)
參數(shù):path(字符串類型) html模板文件的存放路徑。
使用new 操作符建立template對象。
例子:
var tpl = new template("c:\template");
在程序中可以用tpl.tplpath來取得模板路徑,也可以通過tpl.tplpath來改變模板路徑。
如:
tpl.tplpath = "d:\template";
2. 裝載模板文件:template.load(name, file)
參數(shù):name(字符串類型) 是一個模板變量名。
file(字符串類型) 模板文件名。此文件存放在html模板路徑下。
讀取文件file到模板變量name中。
例子:
tpl.load("main", "test.htm");
此時,模板變量main就包含了文件test.htm的內(nèi)容。
你可以用tpl.main來訪問模板變量"main"。
例子:
<%=tpl.main%>
將顯示剛才讀進(jìn)來的test.htm文件內(nèi)容。
3. 模板分拆:template.split(name)
參數(shù):name(字符串類型) 是一個模板變量名。
將name中的子模板分解。
例子:
先假設(shè)上例中的test.htm內(nèi)容為:
-------------------
這是主模板。接下來是:sub子模板,還有
third模板。
-------------------
那么:
tpl.split("main");
執(zhí)行以后,就會生成新的模板變量"sub",和"third",它們的內(nèi)容就是和之間語句。
而且"main"模板變量的內(nèi)容也會發(fā)生改變:
tpl.main 的內(nèi)容為:"這是主模板。接下來是{sub}"
tpl.sub 的內(nèi)容為:"sub子模板,還有{third}"
tpl.third 的內(nèi)容為:"third模板。"
tpldef 和 tplend 定義的語句塊充許多重嵌套。
4. 模板處理:template.parse(name)
參數(shù):name(字符串類型) 是一個模板變量。
將模板中用花括號括起來的字串用同名的模板變量的內(nèi)容替換。
例子:續(xù)上例
<%=tpl.parse("main")%>
顯示:"這是主模板。接下來是sub子模板,還有{third}"
由例子可知,parse只替換"main"模板中的{sub}變量,而不能嵌套替換下去。這是為了增加程序靈活性而故意設(shè)計(jì)的。那么該怎么樣完整顯示"main"模板呢?
例子:
tpl.sub = tpl.parse("sub"); //先處理sub變量,再處理main變量。
response.write(tpl.parse("main"));
5. 自定義模板變量。
自定義模板變量很簡單,可以直接用賦值語句來定義和修改任何變量:
例子:
tpl.hahaha = "這是自定義變量";
tpl.third = "改變原模板中的third變量";
需要注意的是,由于jscrip是區(qū)分大小寫的,因此一定要注意大小寫的拼寫。一般來說,html模板中定義的模板變量都用大寫。
另外,模板中使用的"tplpath","load","parse","split"變量是內(nèi)部使用的,不要挪做它用,否則程序?qū)⒖赡馨l(fā)生異常。
下面舉個完整的例子:
第一步:先建立html模板文件。
這里先說明html模板文件的組成。首先,它和普通的html文件幾乎沒有區(qū)別,只不過多了幾個標(biāo)記。
模板的標(biāo)記有兩種。讓我們先看一個例子:
test.htm
-----------------
范例這是一個表格范例。
以上共有{count}行
數(shù)據(jù)。
-----------------
從上面可以看出,象{x},{xx},{count}之類的記號是定義模板變量。它們將會在asp程序中被替代。
而...是定義一個語句塊"row"。在asp程序中就可以將"row"塊重復(fù)多次。
第二步:設(shè)計(jì)asp程序。
test.asp
-------------------
<%@language=jscript%>
<%
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")%>
-------------------
上面的程序?qū)@示一個1到10的平方表。
通常在使用模板的情況下,都只要在最后一行加上顯示頁面的語句。因此整個程序顯得十分清晰。此時,只要對模板文件進(jìn)行編輯,就可以改變整個頁面的外觀。
至于模板文件,它可以是任何文件,如html文件、asp文件,甚至是程序本身!,而且在一個程序中可以裝載多個模板配合使用,這樣,不僅具有極大靈活性,而且模板文件與asp程序的相關(guān)性可減到最低程度。
好好利用模板,將會使你的工作更加輕松。
附:template 源程序
------------------------------------
<%
/*********************************************************/
/* 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{
key = arr.slice(1,-1);
reg = new regexp(arr,"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("((.|\n)*)","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;
}
%>
該文章在 2010/7/5 0:18:54 編輯過