狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

關于頁面和代碼分離的

admin
2010年7月5日 0:18 本文熱度 6209
為了避免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]范例[br]
[br]
[br][br]這是一個表格范例。[br][br]10 [br][br][br][br][br][br][br][br][br][br]
xx的平方
{x}{xx}
[br]以上共有{count}行[url=http://hackbase.com]數據[/url]。[br][br][br]-----------------[/p]
[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_split(name)[br]{[br]var len = 0;[br]var arr;[br][br]if(this[name]==null)[br]return;[br][br]var template_exp = new regexp("((.|\n)*)","i");[br]while(this[name].search(template_exp)!=-1)[br]{[br]arr = this[name].match(template_exp);[br][br]this[arr[1]] = arr[2];[br]this[name] = this[name].replace(template_exp,"{"+arr[1]+"}");[br]this.split(arr[1]);[br]}[br]}[/p]
[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 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved