寫過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來實現表單處理