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

首頁 > 編程 > VBScript > 正文

VBScript版的PHP extract()函數

2020-06-26 18:38:51
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了VBScript版的PHP extract()函數,extract函數主要作用是把數組轉換成變量,非常好用的一個函數,需要的朋友可以參考下
 

寫過PHP的都知道,其有個extract()非常方便,可以便捷的將字典轉換為變量,當然到ASP中則要受限很多,特別是VBScript腳本,本文敘述的就是一種轉換的思路,可以實現類似的功能。

下面我就直接提供ASP版本的extract代碼吧:

 

復制代碼代碼如下:

'
' ASP/VBScript Dictionary extract
' Author: WangYe
' For more information please visit
'     
' This code is distributed under the BSD license
'
' collection 集合或者字典,可以通過For Each訪問的
'            Request.Form 或者 Request.QueryString
' specified  指定必須存在的屬性,假如該屬性不存在,將自動創建一個
' prefix     每個屬性的前綴修飾
' callback   對于集合或者字典的每個元素(key-value)的值進行函數調用
'            函數原型:
'            Function filter(key, value)
'                filter = value
'            End If
'            最終值將以該函數返回的值為準

Function extract(collection, ByVal specified, prefix, callback)
    Dim VarName, VarValue, DynObj, searchKey
    specified = "," & Replace(specified, " ", "") & ","

    Set DynObj = New DynamicObject
    For Each key In collection
        searchKey = "," & key & ","
        If InStr(1, specified, searchKey, 1)>0 Then
            specified = Replace(specified, searchKey, "")
            If Left(specified, 1) <> "," Then
                specified = "," & specified
            End If
            If Right(specified, 1) <> "," Then
                specified = specified & ","
            End If
        End If

        VarName = prefix & key

        VarValue = collection(key)
        If callback<>"" Then
            VarValue = GetRef(callback)(key, VarValue)
        End If

        DynObj.add VarName, VarValue, PROPERTY_ACCESS_READONLY
 Next

    specified_array = Split(specified, ",")
    Dim i
    For i = LBound(specified_array) To UBound(specified_array)
        If specified_array(i)<>"" Then
            DynObj.add prefix & specified_array(i), "", _
  PROPERTY_ACCESS_READONLY
        End If
    Next
    Set extract = DynObj.GetObject()
End Function

 


再介紹下使用方法:

復制代碼代碼如下:

Dim query
Set query = extract(Request.QueryString, "name,id", "", "")

    Response.Write query.name
    Response.Write query.id

Set query = Nothing

訪問包含上述代碼的ASP頁面,在QueryString(就是URL問號后面的)包含name=wangye你將看到頁面輸出”wangye”,包含id=12的時候,將輸出”12″,當然你也可以同時指定兩項。

 

你可能發現當你Response.Write輸出name和id之外key的時候,程序報錯了,因為指定的屬性不存在,當你在查詢字符串包含這個key的時候,程序又正常了,因為有了這個key就自動建立了屬性,所以又可以直接Response.Write了,如何避免呢?

1. 通過extract()函數的specified參數,該參數是個以逗號隔開key的字符串,你可以看到剛才示例代碼中運用了這個特性,如果查詢字符串未包含相應的key,但是你又使用了這個key,只要specified列表中有,就會自動建立值為空的屬性,所以就不會報錯啦。

2. 通過返回對象的hasattr_方法進行使用前判斷,這個方法可以判斷extract()函數返回的對象是否存在相應的屬性,比如代碼有:

 

復制代碼代碼如下:

Dim query
Set query = extract(Request.QueryString, "name,id", "", "")

If query.hasattr_("job") Then
    Response.Write "Job : " & query.job
End If

Set query = Nothing

這里job并不在我們的specified列表中,但是不帶查詢字串的直接訪問程序沒有報錯,因為我們通過hasattr_在使用前進行判斷是否存在此屬性。

 

3. 通過返回對象的getattr_方法進行安全訪問,這個方法會在使用前判斷指定的屬性是否存在,如果不存在則用默認值替代,詳細參考DynamicObject說明,比如代碼:

復制代碼代碼如下:

Dim query
Set query = extract(Request.QueryString, "name,id", "", "")

    Response.Write "Job : " & query.getattr_("job", "No Job")

Set query = Nothing

最后再介紹下filter的使用,extract()函數的filter參數,指定的是另外一個函數名字符串,然后extract()將對每個值調用該函數進行處理,比如過去有這樣的代碼:
復制代碼代碼如下:

Dim name, job, id
name = Trim(Request.QueryString("name"))
job = Trim(Request.QueryString("job"))
id = CLng(Trim(Request.QueryString("id")))

可以看到,我們每一次都調用了Trim()函數,重復的寫多次很麻煩,而且以后如果要改變相應功能還要一個一個替換,通過filter參數我們可以這樣寫:
復制代碼代碼如下:

'
' Function filter(key, value)
'   filter = Trim(value)
' End Function
'

 

Function filter(key, value)
    On Error Resume Next

    Select Case key
        Case "id" ' 判斷ID是否是數字
            If Not IsNumeric(value) Then
                Exit Function
            End If

            If CLng(value)<1 Then
                Exit Function
            End If
    End Select

    ' 最后記得讓函數返回值,該值在extract將被置為該返回值
    filter = Trim(value)

    If Err.Number<>0 Then
        filter = ""
    End If
End Function

Dim query
Set query = extract(Request.QueryString, "name,id,job", "", "filter")

    Response.Write query.name
    Response.Write query.job
    Response.Write query.id

Set query = Nothing


剛才我們是以Request.QueryString為例子的,當然你也可以使用Request.Form來實現表單處理的更多功能,希望這篇文章能夠給你編寫ASP帶來方便:-)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久精品2019中文字幕神马| 久久亚洲国产精品成人av秋霞| 欧美日韩高清区| 国产精品国内视频| 国产啪精品视频网站| 亚洲天堂免费观看| 日本午夜人人精品| 色偷偷91综合久久噜噜| 欧美日韩国产精品专区| 精品爽片免费看久久| 91产国在线观看动作片喷水| 国产精品久久二区| 96国产粉嫩美女| 成人网址在线观看| 精品亚洲永久免费精品| 国产亚洲欧美aaaa| 免费97视频在线精品国自产拍| 亚洲女人被黑人巨大进入| 欧美电影免费观看大全| 91精品国产高清久久久久久91| 日韩高清av在线| 欧美日韩亚洲高清| 国产精品久久久久久久久久东京| 最好看的2019年中文视频| 一本色道久久88精品综合| 国产亚洲精品91在线| 欧美日韩精品在线视频| 亚洲最新av网址| 久久久久久亚洲精品不卡| 亚洲精品免费av| 亚洲免费电影在线观看| 国产精品91久久久久久| 自拍偷拍亚洲欧美| 亚洲欧美日韩直播| 亚洲精品xxx| 国产精品r级在线| 日韩最新在线视频| 亚洲大胆美女视频| 亚洲大胆人体视频| 欧美黑人极品猛少妇色xxxxx| 91在线播放国产| 国产综合在线看| 亚洲第一福利网站| 性金发美女69hd大尺寸| 国产精品v片在线观看不卡| 欧美黄色三级网站| 成人淫片在线看| 国产精品视频专区| 亚洲精品影视在线观看| 97人人做人人爱| 欧美极度另类性三渗透| 高清一区二区三区日本久| 国产91av在线| 免费不卡欧美自拍视频| 日韩国产一区三区| 欧美国产日韩一区二区三区| 中文字幕少妇一区二区三区| 91免费版网站入口| 狠狠干狠狠久久| 欧美成人亚洲成人| 久久久久久久网站| 日韩av一区在线观看| 国产suv精品一区二区| 一区二区欧美激情| 岛国av在线不卡| 国产成人亚洲综合青青| 日韩精品中文字| 亚洲色图激情小说| 亚洲第一精品久久忘忧草社区| 精品国产欧美一区二区五十路| 国产精品久久久久久一区二区| 国产成人精品av| 综合国产在线视频| 亚洲bt欧美bt日本bt| 亚洲一区二区久久久久久| 夜夜躁日日躁狠狠久久88av| 久久精品国产电影| 久久全球大尺度高清视频| 亚洲综合最新在线| 国产精品亚洲视频在线观看| 国产综合色香蕉精品| 日韩在线观看av| 伊人伊人伊人久久| 亚洲精品黄网在线观看| 久久亚洲一区二区三区四区五区高| 欧美成人剧情片在线观看| 91九色国产在线| 国产精品视频免费观看www| 高清欧美性猛交xxxx黑人猛交| 国自产精品手机在线观看视频| 精品国产区一区二区三区在线观看| 欧美激情一区二区三区成人| 欧美大片在线看| 精品国产福利视频| 精品欧美一区二区三区| 久久免费福利视频| 日韩有码片在线观看| 精品国产91久久久久久| 欧美一级片在线播放| 精品国产鲁一鲁一区二区张丽| 97高清免费视频| 亚洲视频网站在线观看| 中文字幕日韩免费视频| 欧美一区二区三区图| 亚洲精品在线视频| 亚洲一区二区三区久久| 这里只有精品视频在线| 中文字幕欧美日韩va免费视频| 亚洲影视九九影院在线观看| 国产欧美一区二区三区久久人妖| 精品一区二区三区四区在线| 国产精品一区二区三区毛片淫片| 亚洲美女www午夜| 国产精品久久97| 日韩在线免费av| 日韩小视频在线观看| 成人免费在线视频网址| 国色天香2019中文字幕在线观看| 久久国产精彩视频| 国产精品久久久久久久久久三级| 亚洲国产日韩欧美在线动漫| 亚洲xxxx在线| 亚洲美女视频网| 欧美成人亚洲成人| 国产精品视频午夜| 国产精品久久久久久久久免费看| 亚洲欧美国产一本综合首页| 亚洲美女又黄又爽在线观看| 国产精品人成电影| 国产精品va在线播放我和闺蜜| 91精品在线影院| 国产精品亚洲аv天堂网| 亚洲精品视频二区| 国产精品福利在线观看网址| 中文字幕亚洲一区| 欧美电影免费在线观看| 午夜精品视频在线| 少妇高潮久久77777| 最近2019免费中文字幕视频三| 91国产美女在线观看| 一区二区三区视频免费在线观看| 欧美影院久久久| 欧美大尺度激情区在线播放| 欧美黄色小视频| 欧美电影在线免费观看网站| 欧美高清视频在线| 国产精品欧美在线| www.美女亚洲精品| 欧美日韩中文字幕综合视频| 欧美视频在线观看 亚洲欧| 狠狠躁18三区二区一区| 亚洲自拍欧美另类| 欧美成人一二三| 国内免费久久久久久久久久久| 精品视频在线导航| 91美女片黄在线观看游戏| 国产欧美一区二区三区视频| 精品久久久久久久中文字幕| 国产精品视频一| 久久免费视频这里只有精品| 国产精品久久久久久久久粉嫩av| 久久国产精品久久精品| 性色av一区二区三区| 岛国av一区二区三区|