關于頁面和代碼分離的
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
為了避免asp程序和html代碼混寫造成維護困難的情況,本文介紹了一種方法,利用模板來分離程序和頁面,使程序設計更加輕松。
[p][/p] [p][/p] [p]在使用asp制作一個站點的時候,常常會出現一個asp文件中,程序代碼和html代碼混合的情況。這樣子做有許多缺點:[br]1. 且不說[url=http://hackbase.com]編程[/url]時就要對頁面布局進行設計和編排,造成代碼混亂難懂,不規范;[br]2. 當需要改變頁面外觀時,你不僅要改變html部份,也需要改變asp代碼,不易維護。[br][br]那么,要如何才能避免這些麻煩呢?[br]答案就是使用模板文件,將asp代碼和html頁面分開,一切問題就都解決了。使用模板有以下好處:[br]1. 在很短的時間內可以替換整個站點的外觀;[br]2. 使程序員可以抽象[url=http://hackbase.com]編程[/url],而無須接觸html代碼;[br]3. 可以重復利用以前的模板。[/p] [p][br]使用過php的程序就會知道,php有個模板程序(fasttemplate),現在的問題是如何在asp中實現類似的功能。[br]microsoft的asp帶有兩種腳本:vbscript和jscript。它們都帶有一個 "正則表達式對象" (regexp),利用字符串對象和regexp對象,就可以輕松的實現模板功能。沐楓以此編寫了一個 "template.jscript.inc" 文件,此文件的內容附在文章后面。有能力的讀者可以根據自己的需要進行改進。[/p] [p]下面介紹一下使用方法。由于此文件是使用jscript編寫的(當然要轉成vbscript也很容易),因此,缺省腳本語言要設為jscript,即asp程序第一行應為:<%@language=jscript%>,然后再包含模板程序文件:。[/p] [p]先介紹一下template類的使用:[br]1. 建立template對象:template(path)[br]參數:path(字符串類型) html模板文件的存放路徑。[br]使用new 操作符建立template對象。[br][br]例子:[br]var tpl = new template("c:\template"); [/p] [p]在程序中可以用tpl.tplpath來取得模板路徑,也可以通過tpl.tplpath來改變模板路徑。[br]如:[br]tpl.tplpath = "d:\template";[/p] [p]2. 裝載模板文件:template.load(name, file)[br]參數:name(字符串類型) 是一個模板變量名。[br]file(字符串類型) 模板文件名。此文件存放在html模板路徑下。[br]讀取文件file到模板變量name中。[/p] [p]例子:[br]tpl.load("main", "test.htm");[br][br]此時,模板變量main就包含了文件test.htm的內容。[br]你可以用tpl.main來訪問模板變量"main"。[/p] [p]例子:[br]<%=tpl.main%>[br]將顯示剛才讀進來的test.htm文件內容。[/p] [p]3. 模板分拆:template.split(name)[br]參數:name(字符串類型) 是一個模板變量名。[br]將name中的子模板分解。[/p] [p]例子:[br]先假設上例中的test.htm內容為:[br]-------------------[br]這是主模板。接下來是:sub子模板,還有[br]third模板。[br][br]-------------------[br]那么:[br]tpl.split("main");[br]執行以后,就會生成新的模板變量"sub",和"third",它們的內容就是和之間語句。[br]而且"main"模板變量的內容也會發生改變:[/p] [p]tpl.main 的內容為:"這是主模板。接下來是{sub}"[br]tpl.sub 的內容為:"sub子模板,還有{third}"[br]tpl.third 的內容為:"third模板。"[/p] [p]tpldef 和 tplend 定義的語句塊充許多重嵌套。[/p] [p]4. 模板處理:template.parse(name)[br]參數:name(字符串類型) 是一個模板變量。[br]將模板中用花括號括起來的字串用同名的模板變量的內容替換。[br][br]例子:續上例[br]<%=tpl.parse("main")%>[br]顯示:"這是主模板。接下來是sub子模板,還有{third}"[br][br]由例子可知,parse只替換"main"模板中的{sub}變量,而不能嵌套替換下去。這是為了增加程序靈活性而故意設計的。那么該怎么樣完整顯示"main"模板呢?[/p] [p]例子:[br]tpl.sub = tpl.parse("sub"); //先處理sub變量,再處理main變量。[br]response.write(tpl.parse("main"));[/p] [p]5. 自定義模板變量。[br]自定義模板變量很簡單,可以直接用賦值語句來定義和修改任何變量:[/p] [p]例子:[br]tpl.hahaha = "這是自定義變量";[br]tpl.third = "改變原模板中的third變量";[br][br]需要注意的是,由于jscrip是區分大小寫的,因此一定要注意大小寫的拼寫。一般來說,html模板中定義的模板變量都用大寫。[/p] [p]另外,模板中使用的"tplpath","load","parse","split"變量是內部使用的,不要挪做它用,否則程序將可能發生異常。[/p] [p]下面舉個完整的例子:[/p] [p]第一步:先建立html模板文件。[/p] [p]這里先說明html模板文件的組成。首先,它和普通的html文件幾乎沒有區別,只不過多了幾個標記。[br]模板的標記有兩種。讓我們先看一個例子:[/p] [p]test.htm[br]-----------------[br][br][br]
[p]從上面可以看出,象{x},{xx},{count}之類的記號是定義模板變量。它們將會在asp程序中被替代。[br]而...是定義一個語句塊"row"。在asp程序中就可以將"row"塊重復多次。[/p] [p]第二步:設計asp程序。[br][br]test.asp[br]-------------------[br]<%@language=jscript%>[br][br]<%[br]var tpl = new template("c:\inetpub\wwwroot"); [br]var str="";[br]var i;[/p] [p]tpl.load("main","test.htm");[br]tpl.split("main");[/p] [p]tpl.count = 0;[br][br]for(i=1;i<=tpl.maxx;i++) //tpl.maxx在模板中定義為10。[br]{[br]tpl.x = i; [br]tpl.xx = i*i;[br]str+=tpl.parse("row");[br]tpl.count++;[br]}[br]tpl.row = str;[br]tpl.maxx =""; //清空此模板變量,以避免被顯示出來。[br]%>[br]<%=tpl.parse("main")%>[br]-------------------[br]上面的程序將顯示一個1到10的平方表。[/p] [p]通常在使用模板的情況下,都只要在最后一行加上顯示頁面的語句。因此整個程序顯得十分清晰。此時,只要對模板文件進行編輯,就可以改變整個頁面的外觀。[br]至于模板文件,它可以是任何文件,如html文件、asp文件,甚至是程序本身!,而且在一個程序中可以裝載多個模板配合使用,這樣,不僅具有極大靈活性,而且模板文件與asp程序的相關性可減到最低程度。[br]好好利用模板,將會使你的工作更加輕松。[/p] [p][br]附:template 源程序[br]------------------------------------[br][br]<%[br]/*********************************************************/[br]/* template class */[br]/* author: 沐楓 (lin.y@263.net) */[br]/* date: 2000-6-09 */[br]/*********************************************************/[/p] [p]//template method define[/p] [p]function template_parse(name)[br]{[br]if(this[name]==null)[br]return "";[/p] [p]var reg = new regexp("{(\w*)}","ig");[br]var str = new string(this[name]);[br]var arr = str.match(reg);[br]var i;[br][br]if(arr != null) [br]for(i=0;i [p]function template_load(name,filename)[br]{[br]var fso = new activexobject("scripting.filesystemobject");[br]var file = fso.buildpath(this.tplpath, filename);[br]if(fso.fileexists(file))[br]{[br]var f = fso.opentextfile(file, 1);[br]this[name] = f.readall();[br]}[br]}[/p] [p][br]//template constructor[/p] [p]function template(path)[br]{[br]//property[br]this.tplpath = path;[br][br]//method[br]this.parse = template_parse;[br]this.split = template_split;[br]this.load = template_load;[br]}[br]%>[/p] 該文章在 2010/7/5 0:18:54 編輯過 |
關鍵字查詢
相關文章
正在查詢... |