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

首頁 > 學院 > 開發設計 > 正文

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

2019-11-18 19:36:12
字體:
來源:轉載
供稿:網友

文章出處:編程手札
http://blog.csdn.net/nhconch 請大家多多支持.

  每個進行過較大型的asp-Web應用程序設計的開發人員大概都有如下的經歷:ASP代碼與頁面HTML混淆難分,業務邏輯與顯示方式絞合,使得代碼難以理解、難以修改;程序編寫必須在美工之后,成為項目瓶頸;整合的程序代碼和HTML靜態頁面時,花費大量的時間才能得到理想的效果,兼作了美工。的確,用腳本語言開發Web應用不容易將數據的處理和數據的顯示分開,但在多人合作的情況下,如果無法將數據和顯示分開,將大大影響開發的效率,專業分工的發揮。
  其它的腳本語言,如jspphp都有自己的解決方案,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) 輸出處理結果

實現代碼:
<%
'=======================================================================
' 本對象中使用了set_var、set_block等命名方法是為了兼容phplib
'=======================================================================
'www.49028c.com

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("Scr        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 & 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>&nbsp;&nbsp;{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>&nbsp;&nbsp;小豬</td></tr>
    <tr><td>&nbsp;&nbsp;小白</td></tr>
    <tr><td>&nbsp;&nbsp;小強</td></tr>
  <tr><td>植物</td></tr>
    <tr><td>&nbsp;&nbsp;玫瑰</td></tr>
    <tr><td>&nbsp;&nbsp;向日葵</td></tr>
</table>
</body>
</html>


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


4、小結
  本文主要介紹了基于ASP利用模板類實現代碼與頁面分離的方法,當然還有其它更好的解決方案。本文旨在拋磚引玉各位讀者、WEB開發參與進來,多提寶貴意見,多作交流,共同進步!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美大片大片在线播放| 尤物九九久久国产精品的分类| 欧美又大粗又爽又黄大片视频| 国产精品入口免费视| 91久久精品国产91性色| 日韩av片免费在线观看| 中文字幕一精品亚洲无线一区| 亚洲成人激情小说| 中文字幕av一区中文字幕天堂| 亚洲精品有码在线| 欧美大学生性色视频| 亚洲影视九九影院在线观看| 久久精品免费电影| 国产欧美va欧美va香蕉在线| 欧美午夜精品久久久久久人妖| 欧美激情在线狂野欧美精品| 97在线观看免费| 欧美精品videos性欧美| 欧美精品一二区| 国产亚洲精品美女久久久久| 久久久国产视频| 中文字幕亚洲一区二区三区五十路| 人人澡人人澡人人看欧美| 欧美电影免费播放| xvideos亚洲人网站| 日韩中文第一页| 亚洲视频精品在线| 91国产美女视频| 亚洲欧美日本伦理| 国产精品com| 欧美极品在线播放| 欧美日韩在线视频一区| 欧美中文字幕在线观看| 国产精品久久久久不卡| 日韩av不卡电影| 亚洲视频一区二区| 欧美日韩在线视频一区二区| 欧美体内谢she精2性欧美| 国产一区玩具在线观看| 欧美国产日韩一区二区三区| 亚洲精品国产品国语在线| 久久电影一区二区| 亚洲区一区二区| 国产欧美日韩免费看aⅴ视频| 欧美中文在线观看| 欧美精品久久久久久久久| 色老头一区二区三区在线观看| 欧美老女人bb| 日韩欧美国产免费播放| 日韩精品黄色网| 国产精品v片在线观看不卡| 欧美激情免费看| 萌白酱国产一区二区| 久久久999国产| 亚洲国产成人精品一区二区| 亚洲日本成人女熟在线观看| 国产精品成人av在线| 久久精品国产成人精品| 亚洲精品一区中文| 国产精品香蕉av| 中文字幕亚洲字幕| 国产精品91免费在线| 亚洲成人av在线| 国产精品天天狠天天看| 成人免费在线视频网站| 国产在线播放91| www.xxxx欧美| 欧美一级片久久久久久久| 尤物yw午夜国产精品视频明星| 97精品伊人久久久大香线蕉| 45www国产精品网站| 深夜成人在线观看| x99av成人免费| 国产欧美 在线欧美| 国产欧美亚洲视频| 超碰91人人草人人干| 日韩欧美在线视频日韩欧美在线视频| 久久久国产成人精品| 国产精品亚洲自拍| 97碰碰碰免费色视频| 亚洲奶大毛多的老太婆| 亚洲精品福利视频| 少妇高潮久久77777| 国产精品草莓在线免费观看| 久久亚洲精品国产亚洲老地址| 91精品国产91久久久久福利| 亚洲色图25p| 亚洲男女自偷自拍图片另类| 亚洲福利视频专区| 欧美肥老妇视频| 久久视频这里只有精品| 国产精品www色诱视频| 国产精品va在线播放我和闺蜜| 欧美疯狂做受xxxx高潮| 国产精品自产拍在线观看中文| 国产97色在线|日韩| 中文字幕亚洲字幕| 久久久国产精品视频| 亚洲第一级黄色片| 亚洲精品少妇网址| 国产日韩欧美在线观看| 国自产精品手机在线观看视频| 国产精品爽爽爽爽爽爽在线观看| 777国产偷窥盗摄精品视频| 久久久电影免费观看完整版| 久久伊人91精品综合网站| 亚洲精品xxx| 亚洲国产精品久久久久秋霞蜜臀| 国产精品美女www| 日韩精品在线视频| 91av免费观看91av精品在线| 91探花福利精品国产自产在线| 91色p视频在线| 亚洲欧洲av一区二区| 91情侣偷在线精品国产| 97精品国产97久久久久久春色| 成人精品一区二区三区电影免费| 国产999在线| 在线播放日韩精品| 久久九九热免费视频| 亚洲日韩中文字幕| 欧美在线亚洲在线| 国产精品看片资源| 久久精品成人欧美大片| www.精品av.com| 国产免费一区二区三区香蕉精| 亚洲国产精品女人久久久| 不卡伊人av在线播放| 在线播放国产精品| 亚洲区中文字幕| 国产成人拍精品视频午夜网站| 久久久精品日本| 欧美精品情趣视频| 亚洲精品久久7777777| 中文字幕欧美视频在线| 亚洲欧洲偷拍精品| 亚洲成年人影院在线| 国产精品羞羞答答| 成人网页在线免费观看| 国产精品入口免费视频一| 国产福利成人在线| 久久久亚洲欧洲日产国码aⅴ| 日韩av在线直播| 亚洲国产精彩中文乱码av在线播放| 日韩欧中文字幕| 中文字幕av日韩| 日韩av成人在线| 黑人巨大精品欧美一区二区免费| 久久久国产一区二区三区| 欧美日韩xxx| 国产69久久精品成人看| 最近2019年手机中文字幕| 国产在线观看91精品一区| 久久久久国产一区二区三区| 日日骚av一区| 亚洲欧洲国产一区| 欧美日韩在线视频首页| 亚洲女人天堂视频| 欧美性生交xxxxxdddd| 亚洲人线精品午夜| 96pao国产成视频永久免费| 久久精品久久久久电影| 国产一级揄自揄精品视频| 成人高h视频在线|