茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    vbscript版的php extract()函數(shù)
    來源:易賢網(wǎng) 閱讀:1046 次 日期:2016-06-20 09:51:35
    溫馨提示:易賢網(wǎng)小編為您整理了“vbscript版的php extract()函數(shù)”,方便廣大網(wǎng)友查閱!

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

    下面我就直接提供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  指定必須存在的屬性,假如該屬性不存在,將自動創(chuàng)建一個

    ' prefix     每個屬性的前綴修飾

    ' callback   對于集合或者字典的每個元素(key-value)的值進行函數(shù)調(diào)用

    '            函數(shù)原型:

    '            function filter(key, value)

    '                filter = value

    '            end if

    '            最終值將以該函數(shù)返回的值為準

    '

    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″,當然你也可以同時指定兩項。

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

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

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

    代碼如下:

    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()函數(shù)的filter參數(shù),指定的是另外一個函數(shù)名字符串,然后extract()將對每個值調(diào)用該函數(shù)進行處理,比如過去有這樣的代碼:

    代碼如下:

    dim name, job, id

    name = trim(request.querystring(name))

    job = trim(request.querystring(job))

    id = clng(trim(request.querystring(id)))

    可以看到,我們每一次都調(diào)用了trim()函數(shù),重復(fù)的寫多次很麻煩,而且以后如果要改變相應(yīng)功能還要一個一個替換,通過filter參數(shù)我們可以這樣寫:

    '

    ' function filter(key, value)

    '   filter = trim(value)

    ' end function

    '

    function filter(key, value)

        on error resume next

        select case key

            case id ' 判斷id是否是數(shù)字

                if not isnumeric(value) then

                    exit function

                end if

                if clng(value)<1 then

                    exit function

                end if

        end select

        ' 最后記得讓函數(shù)返回值,該值在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來實現(xiàn)表單處理

    更多信息請查看腳本欄目
    易賢網(wǎng)手機網(wǎng)站地址:vbscript版的php extract()函數(shù)

    2026國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)