写过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带来方便:-)

php js vbs,VBScript版的PHP extract()函数相关推荐

  1. Ext JS 6正式版的GPL版本下载地址

    下面是Ext JS 6正式版的GPL版本下载地址 https://www.sencha.com/legal/gpl/ 转载于:https://blog.51cto.com/dqhuang/167041 ...

  2. 火星坐标、百度坐标、WGS84坐标转换代码(JS、python版)

    火星坐标.百度坐标.WGS84坐标转换代码(JS.python版) 一.JS版本源码 github:https://github.com/wandergis/coordTransform /*** C ...

  3. Node.js v7 Beta版引入citgm

    Node.js基金会发布了Node.js v7 Beta版.该版本的发布恰逢v6成为该基金会的第二个LTS版本.在2019年4月份之前,v6版本将可以一直得到积极的技术支持和维护. \\ Node.j ...

  4. Ext JS 5 beta版发布

    原文:Announcing Public Beta of Ext JS 5 我们非常高兴的宣布,Sencha Ext JS 5 beta版本开始进行公测了.这个beta版本可以让你.我们Sencha社 ...

  5. 华为 Mate 40 系列搭载麒麟 9000 芯片;短视频平台 Quibi 宣布关闭;Node.js 15 正式版发布|极客头条

    整理 | 郑丽媛 头图 | CSDN 下载自东方 IC 「极客头条」-- 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「极客头条」来啦,快来看今天都有哪些值得我们技术人关注的重要新闻吧. 国内 ...

  6. Vue.js 2.0版

    Vue.js 2.0版升级,更改了好多方法或指令 new Vue({el:'#demo',data:{msg:"vue2.0"} }) v-model lazy number de ...

  7. 网页版2048html制作,基于HTML+CSS+JS的网页版2048的实现

    ELECTRONICS WORLD·j6: 雾 与 粤 赛 基 于HTM L+CSS+J S的网页:I~2 048的实现 [摘要 ]描述了一个使用HTML和css进行uI界面设计,使用Js进行后台逻辑 ...

  8. 网页版2048html制作,基于HTML+CSS+JS的网页版2048的实现.pdf

    ELECTRONICS WORLD ・探索与观察 基于HTML+CSS+JS的网页版2048的实现 山西农业大学 王艺燕 [摘要] 描述了一个使用HTML和CSS进行UI界面设计,使用JS进行后台逻辑 ...

  9. auto.js 快手极速版刷视频3.0

    auto.js 快手极速版刷视频 结合网上脚本进一步优化 设备: 安卓手机 android 7.0 以上 app: 快手极速版,auto.js 4_1_1. 脚本: kuaishou.js 优化历史 ...

最新文章

  1. svn在linux上的安装
  2. 解决1px的border在移动端变粗的问题
  3. 山东外贸职业学院王彩霞老师网上考试系统及c语言考试题库》,2019年山东外贸职业学院单独招生考试 《语文》考试大纲(夏季高考)...
  4. mac上使用zsh配置环境变量
  5. 与NWBC相关的服务器端配置
  6. 使用 RxJs Observable 来避免 Angular 应用中的 Promise 使用
  7. tp5.0行为的用法,可以存入json数据,方便读取数据。
  8. java 无法加载资源,JavaScript:无法加载资源:服务器响应状态为404(未找到)
  9. sqlite 迁移 oracle,Oracle 数据导入 Sqlite
  10. 【基础数据库】经济行业分类
  11. php paypal网站对接,php 接入 paypal 支付
  12. IE8 证书错误,导航已阻止,解决方法(selenium)
  13. JavaScrpit+Html实现“网页播放视频“效果(应用场景:腾讯PC端视频播放器、以及各视频网站页面开发设计)
  14. 网络工程师之网络规划
  15. gtx660 linux驱动下载,佳能 NVIDIA GeForce GTX660 GPU 驱动程序下载-更新佳能软件(显卡)...
  16. 《Adobe After Effects CS6中文版经典教程》——2.9 渲染合成图像
  17. 区分统一社会信用代码、组织机构代码、注册号
  18. 中国医科大学22春《毛泽东思想和中国特色社会主义理论体系概论(本科)》在线作业【标准答案】
  19. SAA 心理素质差差的
  20. java中高级工程师面试汇总

热门文章

  1. 微信小程序scroll-wiew 横向滚动问题
  2. 学习打卡-2018/08/09
  3. 基于工程经验的『RESTful接口设计规范』
  4. thinkphp-条件判断-范围判断-NOTBETWEEN
  5. node-serialport —— Node.js 串口数据读写包
  6. Qt之自定义界面(窗体缩放)
  7. AIX 访问Linux NFS共享错误案例
  8. OpenJudge 2757 最长上升子序列 / Poj 2533 Longest Ordered Subsequence
  9. JS小功能(操作Table--动态添加删除表格及数据)实现代码
  10. DataTable 转 Entity