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