日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > php >内容正文

php

php js vbs,VBScript版的PHP extract()函数

發(fā)布時(shí)間:2025/3/20 php 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php js vbs,VBScript版的PHP extract()函数 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

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

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

'

' ASP/VBScript Dictionary extract

' Author: WangYe

' For more information please visit

'

' This code is distributed under the BSD license

'

' collection 集合或者字典,可以通過(guò)For Each訪問(wèn)的

'??????????? Request.Form 或者 Request.QueryString

' specified? 指定必須存在的屬性,假如該屬性不存在,將自動(dòng)創(chuàng)建一個(gè)

' prefix???? 每個(gè)屬性的前綴修飾

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

'??????????? 函數(shù)原型:

'??????????? Function filter(key, value)

'??????????????? filter = value

'??????????? End If

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

'

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

訪問(wèn)包含上述代碼的ASP頁(yè)面,在QueryString(就是URL問(wèn)號(hào)后面的)包含name=wangye你將看到頁(yè)面輸出”wangye”,包含id=12的時(shí)候,將輸出”12″,當(dāng)然你也可以同時(shí)指定兩項(xiàng)。

你可能發(fā)現(xiàn)當(dāng)你Response.Write輸出name和id之外key的時(shí)候,程序報(bào)錯(cuò)了,因?yàn)橹付ǖ膶傩圆淮嬖?#xff0c;當(dāng)你在查詢字符串包含這個(gè)key的時(shí)候,程序又正常了,因?yàn)橛辛诉@個(gè)key就自動(dòng)建立了屬性,所以又可以直接Response.Write了,如何避免呢?

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

2. 通過(guò)返回對(duì)象的hasattr_方法進(jìn)行使用前判斷,這個(gè)方法可以判斷extract()函數(shù)返回的對(duì)象是否存在相應(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列表中,但是不帶查詢字串的直接訪問(wèn)程序沒(méi)有報(bào)錯(cuò),因?yàn)槲覀兺ㄟ^(guò)hasattr_在使用前進(jìn)行判斷是否存在此屬性。

3. 通過(guò)返回對(duì)象的getattr_方法進(jìn)行安全訪問(wèn),這個(gè)方法會(huì)在使用前判斷指定的屬性是否存在,如果不存在則用默認(rèn)值替代,詳細(xì)參考DynamicObject說(shuō)明,比如代碼:

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

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)功能還要一個(gè)一個(gè)替換,通過(guò)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為例子的,當(dāng)然你也可以使用Request.Form來(lái)實(shí)現(xiàn)表單處理的更多功能,希望這篇文章能夠給你編寫ASP帶來(lái)方便:-)

總結(jié)

以上是生活随笔為你收集整理的php js vbs,VBScript版的PHP extract()函数的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黄色岛国片| 草草在线免费视频 | 一区二区三区视频免费在线观看 | 欧美专区综合 | 久久国产色av免费观看 | 影音先锋黄色网址 | 男人添女人囗交视频 | 91视频一区二区 | 五月婷婷色 | 欧美人与性动交α欧美片 | 亚洲欧美国产精品专区久久 | 人妻少妇偷人精品无码 | 亚洲午夜小视频 | 亚洲成a人在线观看 | 青青在线观看视频 | 懂色av一区二区三区 | 欧美日批视频 | 三级黄色片免费观看 | 777免费视频 | 国产999精品视频 | 国产成人精品免费在线观看 | 蜜臀av首页 | 亲子乱对白乱都乱了 | 无人在线观看高清视频 单曲 | 久久久久久久久福利 | 欧美一区三区 | 亚洲成人av一区二区 | 91久色蝌蚪 | 人人人插| 美国免费高清电影在线观看 | 午夜天堂在线 | 大肉大捧一进一出好爽视频 | 国产欧美精品aaaaaa片 | 久久精品aaaaaa毛片 | 色性网| 天天久久综合网 | 亚洲成人网av | 一个人免费在线观看视频 | 奇米影视久久久 | 日本免费爱爱视频 | 九九九在线视频 | 琪琪电影午夜理论片八戒八戒 | 黄色片特级| 亚洲精品电影 | 欧美成人aa| 熟妇毛片 | 91精品人妻一区二区 | 1000部拍拍拍18勿入免费视频 | 国产欧美一区二区三区精华液好吗 | 波多野结衣视频在线播放 | 美女少妇av | 国产中文字字幕乱码无限 | 美女露出让男生揉的视频 | 亚洲无码精品在线观看 | 在线日韩一区二区 | 在线观看国产黄 | 欧美日韩一区二区综合 | 欧美大胆视频 | 97视频人人 | 看黄色一级大片 | 98视频在线| 蜜臀av无码精品人妻色欲 | 国产精品一区二区无线 | 2019亚洲男人天堂 | 成人一级毛片 | 丰满人妻综合一区二区三区 | 91精品日韩 | 五月天福利视频 | 波多野结衣亚洲视频 | 国产精品成人久久久 | 伊人网影院 | 国产精品suv一区二区三区 | 日韩aaa| 亚洲精品一区在线 | 国产偷人爽久久久久久老妇app | 日本东京热一区二区 | 午夜av电影在线观看 | 国产社区在线 | 欧美激情xxx | 在线观看成人黄色 | 中日韩在线观看视频 | 国产噜噜噜噜噜久久久久久久久 | 欧美老女人性生活 | 91在线中文 | 日本污网站| 久久久久久1 | av一二三四区 | 久久久精品久久久久久 | av调教 | 亚洲91在线| 一区二区激情视频 | 午夜av影视| 在线观看福利视频 | 日韩蜜桃视频 | 最新中文字幕 | 巨茎人妖videos另类 | 成人免费做受小说 | 久久丁香| 亚洲品质自拍 |