写过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
你可能发现当你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
3. 通过返回对象的getattr_方法进行安全访问,这个方法会在使用前判断指定的属性是否存在,如果不存在则用默认值替代,详细参考DynamicObject说明,比如代码:
Dim query Set query = extract(Request.QueryString, "name,id", "", "") Response.Write "Job : " & query.getattr_("job", "No Job") Set query = Nothing
Dim name, job, id name = Trim(Request.QueryString("name")) job = Trim(Request.QueryString("job")) id = CLng(Trim(Request.QueryString("id")))
' ' 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
问题内容: 我有一个用于ERP系统的快速开发工具,该工具仅允许使用vbscript。我正在尝试使用VBS创建一个简单的AJAX请求。可以使用“ Microsoft.XMLHTTP”对象。 下一步是使用json从网络服务器接收数据。但是在VBS中似乎没有像“ json_decode”或其他功能。 有人知道解决方案吗?还是开发自己的json函数的唯一选择? 问题答案: 由于JSON是一种分层数据格式,
本文向大家介绍VBS基础篇 - vbscript TextStream对象,包括了VBS基础篇 - vbscript TextStream对象的使用技巧和注意事项,需要的朋友参考一下 TextStream对象是用于访问文本文件的对象,它是FileSystemObject一个独立的附属对象,但在使用TextStream对象时,我们仍要借助FileSystemObject 对象或其附属对象来创建一个
对于客户端脚本语言,如果只学 HTML 的话。那是肯定不够用,毕竟现在的网页都是动态的,没有动态效果就像一滩死水一样没有任何吸引力。而 Javascript 和 vbscript 这两种动态客户端脚本语言担当起了把 HTML 静态页面转变成支持用户交互并响应相应时间的活页面的角色。当然动态的客户端脚本语言是不只 Javascript、vbscript 这两种,比如还有 JScript,但是这两种使
本文向大家介绍写出完整版的strcpy函数?相关面试题,主要包含被问及写出完整版的strcpy函数?时的应答技巧和注意事项,需要的朋友参考一下 要点: 使用assert断言函数,判断参数是否为NULL; 遇'\0'则停止赋值; 返回新的字符串的首地址。
这个排版辅助函数文件里的函数能够让你按照相关词性对文本的格局进行排版。 载入这个辅助函数 请使用如下代码载入这个辅助函数:$this->load->helper('typography'); 以下函数可以使用: auto_typography() 格式化文本,使其在语义和排版上是正确的HTML。更多信息请参考 排版类 。 例子:$string = auto_typography($string);
排版辅助函数文件包含了文本排版相关的一些函数。 加载辅助函数 可用函数 加载辅助函数 该辅助函数通过下面的代码加载: $this->load->helper('typography'); 可用函数 该辅助函数有下列可用函数: auto_typography($str[, $reduce_linebreaks = FALSE]) 参数: $str (string) -- Input string