亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

使用模板實現ASP代碼與頁面分離

2024-05-04 11:07:58
字體:
來源:轉載
供稿:網友
每個進行過較大型的ASP-Web應用程序設計的開發人員大概都有如下的經歷:ASP代碼與頁面HTML混淆難分,業務邏輯與顯示方式絞合,使得代碼難以理解、難以修改;程序編寫必須在美工之后,成為項目瓶頸;整合的程序代碼和HTML靜態頁面時,花費大量的時間才能得到理想的效果,兼作了美工。的確,用腳本語言開發Web應用不容易將數據的處理和數據的顯示分開,但在多人合作的情況下,如果無法將數據和顯示分開,將大大影響開發的效率,專業分工的發揮。 
  其它的腳本語言,如JSP、PHP都有自己的解決方案,ASP的后一代產品ASP.NET也實現了代碼與頁面,似乎直接過渡到ASP是不錯的選擇。但是總有這樣或那樣的原因讓我們不能或暫時不能放棄ASP直奔.NET大營。從公司角度來看,轉換語言是一筆不少的投資,包括雇傭熟手.NET程序員、培訓原有程序員、開發工具的轉型、開發風格的轉型、界面風格轉變、接口風格、軟件架構、文檔、開發流程等等;這還意味著原有的代碼必須在新語言環境里重寫以實現最佳的效果和穩定性;同時將直接影響這段時間內項目的進度,更有可能導致個別程序員出走。由此看來在您決定轉換語言之前,在原基礎上尋求一種解決方案,才是最好的選擇。 
  PHP通過模板實現代碼與頁面,可供選擇的有FastTemplate、PHPLIB、Smarty等多種,其中PHPLIB的影響最大、使用最多。既然如此,我們直接把它搬到ASP來,對于同時使用PHP和ASP的公司還有很有好處:一、美工處理頁面時,不管將要套用PHP還是ASP,處理方式是一樣,無須經過培訓;二、程序員編寫代碼時,兩種語言間的思路接近或一致,相同功能在兩種語言實現時,只需拷貝過來略作修改即可,保證了工作效率和項目進度。 

1、模板類的設計 
  實現代碼封裝成為模板類,即是為了與PHPLIB兼容,也使得代碼方便管理與擴展。 
  模板類要實現的目標為:從模板文件中讀入顯示的HTML代碼,將這些顯示代碼中需要動態數據的地方替換為ASP程序運算所得出的數據,然后按照一定的順序輸出。其中,替換的部分可以自由的設定。因此它必須完成如下任務: 
·從模板文件中讀取顯示用的HTML代碼。 
·將模板文件和實際生成的數據結合,生成輸出的結果。 
·允許同時處理多個模板。 
·允許模板的嵌套。 
·允許對模板中的某個單獨的部分進行處理。 

實現方法: 
采用FSO讀取模板文件 
采用正則替換實現模板文件和數據的結合 
處理多個模板用數組存儲來實現。 
模板的嵌套的實現主要的想法是:將模板和輸出(任何中間的分析結果)一視同仁,都可拿來做替換,即可實現。 
單獨部分的處理的通過在模板文件中設定標注,然后在正則替換中結合標注來控制,實現部分替換。 

2、模板類的實現 
  給出具體代碼之前,先把主要函數列出,用過PHPLIB的朋友應該對此很熟悉了: 
  1)Public Sub set_root(ByVal Value) 設定模板默認目錄 
  2)Public Sub set_file(ByVal handle,ByVal filename) 讀取文件 
  3)Public Sub set_var(ByVal Name, ByVal Value, ByVal Append) 設置映射數據-替換變量 
  4)Public Sub unset_var(ByVal Name) 取消數據映射 
  5)Public Sub set_block(ByVal Parent, ByVal BlockTag, ByVal Name) 設置數據塊 
  6)Public Sub set_unknowns(ByVal unknowns) 設定未指定映射的標記處理方式 
  7)Public Sub parse(ByVal Name, ByVal BlockTag, ByVal Append) 執行模板文件與數據的結合
  8)Public Sub p(ByVal Name) 輸出處理結果 

實現代碼: 
<% 
'======================================================================= 
' CLASS NAME: kktTemplate ASP頁面模板對象 
' DESIGN BY : 彭國輝 
' DATE: 2004-07-05 
' WEBSITE: http://kacarton.yeah.net/ 
' EMAIL: kacarton@sohu.com 

' 本對象中使用了set_var、set_block等命名方法是為了兼容phplib 
'======================================================================= 

Class kktTemplate 

Private m_FileName, m_Root, m_Unknowns, m_LastError, m_HaltOnErr 
Private m_ValueList, m_BlockList 
Private m_RegExp 
' 構造函數 
Private Sub Class_Initialize 
Set m_ValueList = CreateObject("Scripting.Dictionary") 
Set m_BlockList = CreateObject("Scripting.Dictionary") 
set m_RegExp = New RegExp 
m_RegExp.IgnoreCase = True 
m_RegExp.Global = True 
m_FileName = "" 
m_Root = "" 
m_Unknowns = "remove" 
m_LastError = "" 
m_HaltOnErr = true 
End Sub 

' 析構函數 
Private Sub Class_Terminate 
Set m_RegExp = Nothing 
Set m_BlockMatches = Nothing 
Set m_ValueMatches = nothing 
End Sub 

Public Property Get ClassName() 
ClassName = "kktTemplate" 
End Property 

Public Property Get Version() 
Version = "1.0" 
End Property 

Public Sub About() 
Response.Write("kktTemplate ASP頁面模板類<br>" & vbCrLf &_ 
"程序設計:彭國輝 2004-07-05<br>" & vbCrLf &_ 
"個人網站:<a href='http://kacarton.yeah.net'>http://kacarton.yeah.net<;/a><br>" & vbCrLf &_ 
"電子郵件:<a href='mailto:kacarton@sohu.com'>kacarton@sohu.com</a><br>") 
End Sub 

'檢查目錄是否存在 
Public Function FolderExist(ByVal path) 
Dim fso 
Set fso = CreateObject("Scripting.FileSystemObject") 
FolderExist = fso.FolderExists(Server.MapPath(path)) 
Set fso = Nothing 
End Function 
'讀取文件內容 
Private Function LoadFile() 
Dim Filename, fso, hndFile 
Filename = m_Root 
If Right(Filename, 1)<>"/" And Right(Filename, 1)<>"/" Then Filename = Filename & "/" 
Filename = Server.MapPath(Filename & m_FileName) 
Set fso = CreateObject("Scripting.FileSystemObject") 
If Not fso.FileExists(Filename) Then ShowError("模板文件" & m_FileName & "不存在!") 
set hndFile = fso.OpenTextFile(Filename) 
LoadFile = hndFile.ReadAll 
Set hndFile = Nothing 
Set fso = Nothing 
If LoadFile = "" Then ShowError("不能讀取模板文件" & m_FileName & "或文件為空!") 
End Function 

'處理錯誤信息 
Private Sub ShowError(ByVal msg) 
m_LastError = msg 
Response.Write "<font color=red style='font-size;14px'><b>模板錯誤:" & msg & "</b></font><br>" 
If m_HaltOnErr Then Response.End 
End Sub 

'設置模板文件默認目錄 
'Ex: kktTemplate.set_root("/tmplate") 
' kktTemplate.Root = "/tmplate" 
' root = kktTemplate.get_root() 
' root = kktTemplate.Root 
'使用類似set_root這樣的命名方法是為了兼容phplib,以下將不再重復說明 
Public Sub set_root(ByVal Value) 
If Not FolderExist(Value) Then ShowError(Value & "不是有效目錄或目錄不存在!") 
m_Root = Value 
End Sub 
Public Function get_root() 
get_root = m_Root 
End Function 
Public Property Let Root(ByVal Value) 
set_root(Value) 
End Property 
Public Property Get Root() 
Root = m_Root 
End Property 

'設置模板文件 
'Ex: kktTemplate.set_file("hndTpl", "index.htm") 
'本類不支持多模板文件,handle為兼容phplib而保留 
Public Sub set_file(ByVal handle,ByVal filename) 
m_FileName = filename 
m_BlockList.Add Handle, LoadFile() 
End Sub 
Public Function get_file() 
get_file = m_FileName 
End Function 
' Public Property Let File(handle, filename) 
' set_file handle, filename 
' End Property 
' Public Property Get File() 
' File = m_FileName 
' End Property 

'設置對未指定的標記的處理方式,有keep、remove、comment三種 
Public Sub set_unknowns(ByVal unknowns) 
m_Unknowns = unknowns 
End Sub 
Public Function get_unknowns() 
get_unknowns = m_Unknowns 
End Function 
Public Property Let Unknowns(ByVal unknown) 
m_Unknowns = unknown 
End Property 
Public Property Get Unknowns() 
Unknowns = m_Unknowns 
End Property 

Public Sub set_block(ByVal Parent, ByVal BlockTag, ByVal Name) 
Dim Matches 
m_RegExp.Pattern = "<!--/s+BEGIN " & BlockTag & "/s+-->([/s/S.]*)<!--/s+END " & BlockTag & "/s+-->" 
If Not m_BlockList.Exists(Parent) Then ShowError("未指定的塊標記" & Parent) 
set Matches = m_RegExp.Execute(m_BlockList.Item(Parent)) 
For Each Match In Matches 
m_BlockList.Add BlockTag, Match.SubMatches(0) 
m_BlockList.Item(Parent) = Replace(m_BlockList.Item(Parent), Match.Value, "{" & Name & "}") 
Next 
set Matches = nothing 
End Sub 

Public Sub set_var(ByVal Name, ByVal Value, ByVal Append) 
Dim Val 
If IsNull(Value) Then Val = "" Else Val = Value 
If m_ValueList.Exists(Name) Then 
If Append Then m_ValueList.Item(Name) = m_ValueList.Item(Name) & Val _ 
Else m_ValueList.Item(Name) = Val 
Else 
m_ValueList.Add Name, Value 
End If 
End Sub 

Public Sub unset_var(ByVal Name) 
If m_ValueList.Exists(Name) Then m_ValueList.Remove(Name) 
End Sub 

Private Function InstanceValue(ByVal BlockTag) 
Dim keys, i 
InstanceValue = m_BlockList.Item(BlockTag) 
keys = m_ValueList.Keys 
For i=0 To m_ValueList.Count-1 
InstanceValue = Replace(InstanceValue, "{" & keys(i) & "}", m_ValueList.Item(keys(i))) 
Next 
End Function 

Public Sub parse(ByVal Name, ByVal BlockTag, ByVal Append) 
If Not m_BlockList.Exists(BlockTag) Then ShowError("未指定的 塊標記" & Parent) 
If m_ValueList.Exists(Name) Then 
If Append Then m_ValueList.Item(Name) = m_ValueList.Item(Name) & InstanceValue(BlockTag) _ 
Else m_ValueList.Item(Name) = InstanceValue(BlockTag) 
Else 
m_ValueList.Add Name, InstanceValue(BlockTag) 
End If 
End Sub 

Private Function finish(ByVal content) 
Select Case m_Unknowns 
Case "keep" finish = content 
Case "remove" 
m_RegExp.Pattern = "/{[^ /t/r/n}]+/}" 
finish = m_RegExp.Replace(content, "") 
Case "comment" 
m_RegExp.Pattern = "/{([^ /t/r/n}]+)/}" 
finish = m_RegExp.Replace(content, "<!-- Template Variable $1 undefined -->") 
Case Else finish = content 
End Select 
End Function 

Public Sub p(ByVal Name) 
If Not m_ValueList.Exists(Name) Then ShowError("不存在的標記" & Name) 
Response.Write(finish(m_ValueList.Item(Name))) 
End Sub 
End Class 
%> 

3、使用例子 
  下面舉三個例子進行說明。 
1)簡單的值替換 
模板文件為myTemple.tpl,內容: 
<html><title>ASP模板簡單替換</title><body> 
祝賀!你贏了一輛{some_color}法拉利! 
</body> 

下面是ASP代碼(kktTemplate.inc.asp就是上面給出的模板類): 
<!--#INCLUDE VIRTUAL="kktTemplate.inc.asp"--> 
<% 
dim my_color, kkt 
my_color = "紅色的" 
set kkt = new kktTemplate '創建模板對象 
kkt.set_file "hndKktTemp", "myTemple.tpl" '設置并讀取模板文件myTemple.tpl 
kkt.set_var "some_color", my_color, false '設置模板變量 some_color = my_color的值 
kkt.parse "out", "hndKktTemp", false '模板變量 out = 處理后的文件 
kkt.p "out" '輸出out的內容 
set kkt = nothing '銷毀模板對象 
%> 

執行后輸出為: 
<html><title>ASP模板簡單替換</title><body> 
祝賀!你贏了一輛紅色的法拉利! 
</body> 


2)循環塊演示例子 
模板文件myTemple2.tpl: 
<html><title>ASP模板-塊的演示</title><body> 
<table cellspacing="2" border="1"><tr><td>下面的動物您喜歡哪一種</td></tr> 
<!-- BEGIN AnimalList --> 
<tr><td><input type="radio" name="chk">{animal}</td></tr> 
<!-- END AnimalList --> 
</table> 
</body> 

ASP代碼: 
<!--#INCLUDE VIRTUAL="kktTemplate.inc.asp"--> 
<% 
dim animal, kkt, i 
animal = Array("小豬","小狗","小強") 
set kkt = new kktTemplate 
kkt.set_file "hndKktTemp", "myTemple2.tpl" 
kkt.set_block "hndKktTemp", "AnimalList", "list" 
for i=0 to UBound(animal) 
kkt.set_var "animal", animal(i), false 
kkt.parse "list", "AnimalList", true 
next 
kkt.parse "out", "hndKktTemp", false 
kkt.p "out" 
set kkt = nothing 
%> 

執行結果: 
<html><title>ASP模板-塊的演示</title><body> 
<table cellspacing="2" border="1"><tr><td>下面的動物您喜歡哪一種</td></tr> 
<tr><td><input type="radio" name="chk">小豬</td></tr> 
<tr><td><input type="radio" name="chk">小狗</td></tr> 
<tr><td><input type="radio" name="chk">小強</td></tr> 
</table> 
</body> 


3)嵌套塊演示 
模板文件myTemple3.tpl: 
<html><title>ASP模板-嵌套塊演示</title> 
<body><table width="400" border="1" bordercolor="#000000"> 
<tr><td><div align="center">{myname}測試</div></td></tr> 
<tr><td>我的動植物園:</td> </tr> 
<!-- BEGIN animalList --> 
<tr><td>{animal}</td></tr> 
<!-- BEGIN plantList --> 
<tr><td> {plant}</td></tr> 
<!-- END plantList --> 
<!-- END animalList --> 
</table> 
</body> 
</html> 

ASP代碼: 
<!--#INCLUDE VIRTUAL="kktTemplate.inc.asp"--> 
<% 
dim my_color, kkt, myname, animal, plant 
set kkt = new kktTemplate 
myname = "kktTemplate block test..." 
animal = array("動物", "植物") 
plant = array(array("小豬","小白","小強"), array("玫瑰","向日葵")) 

kkt.set_file "hndKktTemp", "myTemple3.tpl" 
kkt.set_var "myname", myname, false 
kkt.set_block "hndKktTemp", "animalList", "a" 
kkt.set_block "animalList", "plantList", "p" 

for i=0 to UBound(animal) 
kkt.set_var "animal", animal(i), False 
kkt.unset_var "p" 
'kkt.set_var "p", "", false 
for j=0 to UBound(plant(i)) 
kkt.set_var "plant", plant(i)(j), false 
kkt.parse "p", "plantList", true 
next 
kkt.parse "a", "animalList", true 
next 
kkt.parse "out", "hndKktTemp", false 
kkt.p "out" 
%> 

執行結果: 
<html><title>ASP模板-嵌套塊演示</title> 
<body><table width="400" border="1" bordercolor="#000000"> 
<tr><td><div align="center">kktTemplate block test...測試</div></td></tr> 
<tr><td>我的動植物園:</td> </tr> 
<tr><td>動物</td></tr> 
<tr><td> 小豬</td></tr> 
<tr><td> 小白</td></tr> 
<tr><td> 小強</td></tr> 
<tr><td>植物</td></tr> 
<tr><td> 玫瑰</td></tr> 
<tr><td> 向日葵</td></tr> 
</table> 
</body> 
</html> 


本文提及的所有代碼可從此處下載:http://www.freewebs.com/kacarton/web/kktTemplate.rar(3.53K) 


4、小結 
  本文主要介紹了基于ASP利用模板類實現代碼與頁面分離的方法,當然還有其它更好的解決方案。本文旨在拋磚引玉各位讀者、WEB開發參與進來,多提寶貴意見,多作交流,共同進步!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
夜夜躁日日躁狠狠久久88av| 日韩av综合中文字幕| 亚洲欧美日韩成人| 国产成人精品在线观看| 日韩欧美中文第一页| 日本亚洲欧美三级| 国产成人精品免费久久久久| 91人成网站www| 一本色道久久综合狠狠躁篇怎么玩| 亚洲精品在线视频| 国产精品99导航| 国产一区二区丝袜| 91国产视频在线播放| 久久亚洲精品视频| 亚洲精品美女在线观看播放| 久久久久国产一区二区三区| 亚洲人成啪啪网站| 日韩av一区在线| 57pao成人永久免费视频| 国产香蕉97碰碰久久人人| 亚洲欧洲日韩国产| 国产精品免费视频久久久| 亚洲性夜色噜噜噜7777| 日韩中文字幕在线| 亚洲视频视频在线| 91精品国产综合久久香蕉最新版| 亚洲欧美日韩一区二区在线| 久久中文字幕视频| 亚洲嫩模很污视频| 国产精欧美一区二区三区| 久久久久久久999| 免费97视频在线精品国自产拍| 久久久久久噜噜噜久久久精品| 一区二区三区高清国产| 26uuu日韩精品一区二区| 一本色道久久综合狠狠躁篇怎么玩| 国自产精品手机在线观看视频| 中文字幕日韩视频| 日本国产高清不卡| 国产欧美日韩中文字幕在线| 久久国产一区二区三区| 日韩高清有码在线| 欧美精品videosex极品1| 91禁外国网站| 26uuu亚洲伊人春色| 精品国产精品自拍| 欧美精品电影在线| 日韩精品视频免费专区在线播放| 国产精品入口日韩视频大尺度| 国产精品久久久久久久久久久新郎| 日韩电影中文 亚洲精品乱码| 欧美视频在线观看 亚洲欧| 日韩中文字幕免费| 日韩欧美成人免费视频| 国产精品一区二区三| 欧美电影免费观看大全| 久久综合久久88| 欧美xxxx综合视频| 在线观看亚洲区| 久久精品视频在线播放| 日本免费一区二区三区视频观看| 国产精品视频999| 日韩电影在线观看永久视频免费网站| 欧美尺度大的性做爰视频| 日韩精品免费在线视频观看| 色老头一区二区三区在线观看| 国产精品免费久久久久影院| 日韩亚洲第一页| 日本午夜精品理论片a级appf发布| 久久精品久久久久| 久久精品中文字幕免费mv| 91国产视频在线| 在线日韩精品视频| 亚洲欧美激情在线视频| 午夜精品久久久久久久男人的天堂| 久久福利网址导航| 国产极品精品在线观看| 精品成人国产在线观看男人呻吟| 69**夜色精品国产69乱| 亚洲欧洲免费视频| 欧美日韩亚洲精品内裤| 国产丝袜视频一区| 国产午夜精品免费一区二区三区| 亚洲人成网站777色婷婷| 一区二区三区回区在观看免费视频| 久久香蕉国产线看观看av| 亚洲最新av在线网站| 欧美黄网免费在线观看| 久久精品视频在线| 亚洲一区www| 日本一本a高清免费不卡| 国产91九色视频| 久久亚洲综合国产精品99麻豆精品福利| 久久99久久亚洲国产| 亚洲级视频在线观看免费1级| 精品日韩中文字幕| 97高清免费视频| 欧美中文字幕在线视频| 91久久久久久| 日韩麻豆第一页| 日韩精品在线观看一区| 久久久女女女女999久久| 欧美性生交xxxxx久久久| 国产欧美日韩综合精品| 国产精品视频精品视频| 亚洲成人精品在线| 国产精品一区二区在线| 一个人看的www欧美| 亚洲欧美在线一区| 日本一本a高清免费不卡| 亚洲电影免费观看高清完整版| 色婷婷久久av| 亚洲黄页视频免费观看| 亚洲精品自拍第一页| 日韩中文理论片| 欧美精品日韩www.p站| 91老司机精品视频| 日韩精品欧美激情| 欧美日本精品在线| 亚洲日韩欧美视频一区| 两个人的视频www国产精品| 性色av一区二区三区在线观看| 久久综合五月天| 久久夜色精品亚洲噜噜国产mv| 国产精品久久久久久久久粉嫩av| 亚洲尤物视频网| 欧美激情视频免费观看| 91精品国产九九九久久久亚洲| yellow中文字幕久久| 国产一区二区三区中文| 国产一区二区视频在线观看| 欧美视频免费在线| 欧美日韩电影在线观看| 青青草一区二区| 91牛牛免费视频| 69国产精品成人在线播放| 美女av一区二区| 91精品久久久久久久| 中文字幕久久久| 日韩精品免费在线视频观看| 热草久综合在线| 国产精品精品视频| 精品夜色国产国偷在线| 久久久精品2019中文字幕神马| 亚洲成人黄色在线| 精品国产一区二区在线| 欧美在线视频在线播放完整版免费观看| 国产69精品久久久久久| 日韩综合中文字幕| 国产男人精品视频| 久久99久国产精品黄毛片入口| 国产精品揄拍一区二区| 欧美亚洲视频在线看网址| 欧美成人精品在线视频| 91久久精品国产91久久| 国产精品精品视频| 91中文精品字幕在线视频| 精品成人国产在线观看男人呻吟| 国产男女猛烈无遮挡91| 日韩在线中文字| 国产偷国产偷亚洲清高网站| 欧美老少配视频| 久久国产色av| 国产999精品视频|