首页 > 编程 > ASP > 正文

如何在ASP中遍历和操作Application对象的集合_ASP教程

2024-05-04 11:04:02
字体:
来源:转载
供稿:网友

推荐:一些值得收藏的ASP代码
值得收藏的一些ASP代码值得收藏的一些ASP代码 1. oncontextmenu=window.event.returnvalue=false 将彻底屏蔽鼠标右键 table border oncontextmenu=return(false)tdno/table 可用于Table 2. body onselectstart=return false 取消选

为了能够正常使用,必须把它们放到服务器上的一个虚拟应用程序内,并且把所提供的global.asa文件放到该应用程序的根目录中。最简单的办法是把global.asa文件放到缺省Web网站的根目录(缺省情况下是C:/InetPub/WWWRoot)中。

对任何已有的global.asa文件重命名是一个好办法,可以在以后对该文件进行恢复。

1. 显示Application集合的内容

ASPCounter对象是StaticObjects集合的一个成员(通过<OBJECT>元素进行定义),但是其余部份(由Server.CreateObject实例化)是Contents集合的成员。

可以看到使用global.asa例子网页放到这些集合中的值,这在前面已经看到:

以下为引用的内容:

<!-- Declare instance of the ASPCounter component with

application-level scope //-->

<OBJECT ID=”ASPCounter” RUNAT=”Server” SCOPE=”Applicatoin”

PROGID=”MSWC.Counters”>

</OBJECT>

...

...

<SCRIPT LANGUAGE=”VBScript” RUNAT=”Server”>

Sub Application_onStart()

‘Create an instance of an ADO Connection with application-level scope

Set Application(“ADOConnection”) = Server.CreateObject(“ADODB.Connection”)

Dim varArray(3) ‘Create a Variant array and fill it

varArray(0) = “This is a”

varArray(1) = “Variant array”

varArray(2) = “stored in the”

varArray(3) = “Application object”

Application(“Variant_Array”) = varArray ‘Store it in thd Application

Application(“Start_Time”) = CStr(Now) ‘Store the date/time as a string

Application(“Visit_Count”) = 0 ‘Set counter variable to zero

End Sub

...

...

</SCRIPT>

(1) 遍历Contents集合的代码

为了遍历Contents集合,可使用一个For Each ... Next结构。集合中的每一项可以是一个简单的Variant类型变量、一个Variant数组或者一个对象的引用。因为需要对每种类型的值进行不同的处理,所以就不得不对每一个进行检查来判别其类型。

在VBScript中可使用VarType函数完成这个工作。这里使用IsObject和IsArray函数代替:

以下为引用的内容:

For Each objItem in Application.Contents

If IsObject(Application.Contents(objItem)) Then

Response.Write “Object reference: ‘” & objItem & “’

ElseIf IsArray(Application.Contents(objItem)) Then

Response.Write “Array: ‘” & objItem & “’ contents are:

VarArray = Application.Contents(objItem)

‘Note: the following only works with a one-dimensional array

For intLoop = 0 To UBound(varArray)

Response.Write “ Index(“ & intLoop & “) = “ & _

VarArray(intLoop) & “


Next

Else

Response.Write “Variable: ‘” & objItem & “’ = “ _

& Application.Contents(objItem) & “


End If

Next

注意程序如何从Application对象检索该数组。将其分配给一个局部(Variant)变量,使用下面的语句:

varArray = Application.Contents(objItem)

使用UBound函数可以查找出数组的大小(元素的数量),这个值可以作为遍历的终止条件:

For intLoop = 0 UBound(varArray)

这个例子是一维数组,并将只显示这样的一个数组的内容。可根据需要编辑代码以处理多维数组,例如:

以下为引用的内容:

For intLoop = 0 To UBound(varArray)

IntNumberOfDimensions = UBound(varArray, 1)

For intDimension = 0 To intNumberOfDimensions

Response.Write “ Index(“ & intLoop & “) = “ _

& varArray(intLoop, intDimension)

Next

Response.Write “”

Next

(2) 遍历StaticObjects集合的代码

StaticObjects集合包含了所有在global.asa中使用<OBJECT>元素声明的对象引用。因为每个条目都是一个对象变量,可用简单些的代码对这个数组进行遍历。我们将输出对象的名字(在ID属性中原有的定义):

以下为引用的内容:

For Each objItem in Application.StaticObjects

If IsObject(Application.StaticObjects(objItem)) Then

Response.Write “<OBJECT> element: ID=’” & objItem & “’

End If

Next

分享:ASP编程中11种数据库的常用语法
本文主要介绍了ASP连接11种数据库的常用语法,详细内容请参考下文: 1.Access数据库的DSN-less连接方法: 以下为引用的内容: set adocon=Server.Createobject(adodb.connection) adoconn.OpenDriver={Microsoft Access Driver(*.mdb)};DBQ= _ Server.MapPath

共2页上一页12下一页
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表