分享
 
 
 

ASP中使用Form和QueryString集合

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

当用户填写页面<FORM>内容时所提供的全部值,或在浏览器地址栏输入在URL后的值,通过Form和QueryString集合为ASP脚本所用。这是在ASP代码中访问值的一种简单方法。

1、 访问ASP集合的一般技术

大多数ASP集合与在VB中见到的普通集合相差不多。实际上,它们是值的数组,但能通过使用一个文本字符串键(对大小不敏感)以及一个整型索引进行访问。因此,假如客户端Web页面包含的<FORM>如下:

<FORM ACTION=”show_request.asp” METHOD=”POST”>

FirstName:<INPUT TYPE=”TEXT” NAME=”FirstName”>

LastName:<INPUT TYPE=”TEXT” NAME=”LastName”>

<INPUT TYPE=”SUBMIT” VALUE=”Send”>

</FORM>

可通过访问ASP的Form集合来访问其控件内的值:

strFirstName = Request.Form(“FirstName”)

strLastName = Request.Form(“LastName”)

也可使用窗体中控件的整型索引,索引的范围从在HTML中第一个定义的控件开始,然后根据定义的顺序排序:

strFirstName = Request.Form(1)

strLastName = Request.Form(2)

然而,后面的这种以整型为索引的技术不推荐使用,因为一旦有HTML中的控件发生了变化,或者插入一个新的控件,则ASP代码将得到错误的值。进一步而言,对于阅读代码的人来讲,极容易混淆。

1) 访问集合的全部值

可以通过引用集合把整个Form上的一系列值变成单个的字符变量,且不用提供键或索引。

StrAllFormContent = Request.Form

假如文本框包含值Priscilla和Descartes,则Request.Form语句将返回下列字符:

FirstName=Priscilla&LastName=Descartes

注意,提供的值是以名称/值对的形式出现的(即控件名称=控件值),并且每一对名称/值相互之间是用符号“&”相分隔的。假如打算把窗体中的内容传递单独的,希望得到值的标准格式的可执行应用程序或DLL,这个技术是很有用的。然而,一般说来,都是通过以窗体中控件的名称为文本键来访问集合中的内容。

2) 遍历一个ASP集合

有两种方式遍历一个ASP集合中的所有成员,方式与普通VB集合的基本相同。每个集合提供一个Count属性,返回的是集合中条目数量。可通过使用一个整型索引使用Count属性来遍历。

For intLoop=1 To Request.Form.Count

Response.Write Request.Form(intLoop) & “<BR>”

Next

假如先前的窗体包含Priscilla和Descartes值的两个文本框,将得到如下结果:

Priscilla

Descartes

然而,更好的方法是使用For Each...Next结构。

For Each objItem In Request.Form

Response.Write objItem & “=” & Request.Form(objItem) & “<BR>”

Next

这带来的好处是既可以访问控件的名称又可访问其值。上述代码将得到如下结果:

FirstName = Priscilla

LastName = Descartes

注意,一些浏览器返回到ASP的<FORM>值可能与页面上显示的顺序不尽相同。

3) 集合成员的多值性

在某些情况下,ASP集合中的各个成员可能不止一个值,这种情况发生在HTML定义中有几个控件有相同Name属性时。例如:

<FORM ACTION=”Show_request.asp” METHOD=”POST”>

<INPUT TYPE=”TEXT” NAME=”OtherHobby”>

<INPUT TYPE=”TEXT” NAME=”OtherHobby”>

<INPUT TYPE=”TEXT” NAME=”OtherHobby”>

<INPUT TYPE=”SUBMIT” VALUE=”Send”>

</FORM>

在Form集合中,将为“OtherHobby”创建一个条目。然而,它将包括从三个文本框中得到的值。假如在提交时,用户留下了一个或多个为空,则返回的值为空字符串。假如用户在第一和第三个文本框分别输入Gardening和Mountaineering,第二个文本框为空,在我们的ASP代码中访问Request.Form(“OtherHobby”),将返回字符串:

Gardening, ,Mountaineering

为了能够在这种情况下,访问单个值,可以用复杂一些的代码:

For Each objItem In Request.Form

If Request.Form(objItem).Count >1 Then ‘More than one value in this item Response.Write objItem & “:<BR>”

For intLoop = 1 To Request.Form(objItem).Count

Response.Write “Subkey” & intLoop & “value = “& Request.Form(objItem) (intLoop) & “<BR>”

Next

Else

Response.Write objItem & “ = ” & Request.Form(objItem) & “<BR>”

End If

Next

对于前面的包含三个OtherHobby控件的窗体实例,这将返回:

OtherHobby:

Subkey 1 value = Gardening

Subkey 2 value =

Subkey 3 value = Mountaineering

然而,由于很少给多个文本框相同的名字,因此这种技术很少用到。

a) HTML中的单选或选页按钮控件

在HTML中,需要给几个控件相同的Name属性的情况是单选(或选项)按钮,例如:

<FORM ACTION=”show_request.asp” METHOD=”POST”>

I live in:

<INPUT TYPE=”RADIO” NAME=”Country” VALUE=”AM”>America<BR>

<INPUT TYPE=”RADIO” NAME=”Country” VALUE=”EU”>Europe<BR>

<INPUT TYPE=”RADIO” NAME=”Country” VALUE=”AS”>Asia<BR>

<INPUT TYPE=”SUBMIT” VALUE=”Send”>

</FORM>

因为用户只能选择多项中的一个(这就是给它们相同的名字的原因),将仅得到一个返回值,浏览器只能发送所选择控件的值。因此,假如这个窗体的用户已经选择了“Europez”,将得到这个条目,通过遍历Form集得到其值:

Country = EU

由于为每个控件提供了不同的VALUE属性,反映了每个条目所对应的国家或地区的名称。假如省略了VALUE属性,浏览器将返回的值为“on”,因此将得到:

Country = on

这是不经常用到的,因此一般对使用相同名称的单选控件使用VALUE属性。

b) HTML复选框控件

当一个窗体中HTML源码包含一个复选框控件时,一般都给定唯一的名称,例如:

<FORM ACTION=”show_request.asp” METHOD=”POST”>

I enjoy:

<INPUT TYPE=”CHECKBOX” NAME=”Reading” CHECKED> Reading

<INPUT TYPE=”CHECKBOX” NAME=”Eating”> Eating

<INPUT TYPE=”CHECKBOX” NAME=”Sleeping”> Sleeping

<INPUT TYPE=”SUBMIT” VALUE=”Send”>

</FORM>

在这种情况下,提交窗体时,假如仅是第一和第三个复选框被选中(加标记),遍历Form集合时,会得到下列值:

Reading = on

Sleeping = on

然而,假如为每个复选框提供一个值,把这个值发往服务器代替字符串“on”。例如窗体如下:

<FORM ACTION=”show_request.asp” METHOD=”POST”>

I enjoy:

<INPUT TYPE=”CHECKBOX” VALUE=”Hobby025” NAME=”Hobby” CHECKED>_

Swimming

<INPUT TYPE=”CHECKBOX” VALUE=”Hobby003” NAME=”Hobby” CHECKED>_

Reading

<INPUT TYPE=”CHECKBOX” VALUE=”Hobby068” NAME=”Hobby”>Eating

<INPUT TYPE=”CHECKBOX” VALUE=”Hobby010” NAME=”Hobby”>Sleeping

<INPUT TYPE=”SUBMIT” VALUE=”Send”>

</FORM>

如果除第三个复选框外,全部提交,在Request.Form集合会产生下列结果:

Hobby = Hobby025, Hobby003, Hobby010

假如编写更复杂一些集合遍历代码,如先前所述(单独显示每个子键),就得到这样结果:

Hobby:

Subkey 1 value = Hobby025

Subkey 2 value = Hobby003

Subkey 3 value = Hobby010

需要注意的是两种情况,没有选中的控件根本不返回任何值。在第一种情况的结果里,没有欺骗性的逗号,第二种情况也没有空值。这与上述的使用文本框的相当的测试的结果不一样。使用文本框时,每个文本框都返回一个值,即使是一个空字符串。这是浏览器造成这样的结果。因此在ASP代码中访问集合时,要注意这个问题。

上述情况一个棘手的负作用是使用复选框时,复选框值的索引与在原始的HTML中控件的位置没有任何联系,在上述的例子中第四个复选框的子键数为3,因为当窗体提交时,第二个控件没有选中。

c) HTML列表控件

HTML中的<SELECT>标记用来产生标准的下拉列表框,其值以一种有趣的混合方式表示。下列的窗体创建了包含5个值可供用户选择,由于包含了MULTIPLE属性,因此可以通过选择时按下Shift或Ctrl键,选择不仅一个的条目。

<FORM ACTION=”show_request.asp” METHOD=”POST”>

<SELECT NAME=”Hobby” SIZE=”5” MULTIPLE>

<OPTION VALUE=”Hobby001”>Programming</OPTION>

<OPTION VALUE=”Hobby025”>Swimming</OPTION>

<OPTION VALUE=”Hobby003”>Reading</OPTION>

<OPTION VALUE=”Hobby068”>Eating</OPTION>

<OPTION VALUE=”Hobby010”>Sleeping</OPTION>

</SELECT><P>

<INPUT TYPE=”SUBMIT” VALUE=”Send”>

</FORM>

这种特殊的情况返回的是在Form集合中单个条目,它包含选择的值(单个的<OPTION>标记中指定的VALUE属性),用逗号分隔:

Hobby = Hobby025, Hobby003, Hobby010

假如使用更加复杂一些的集合遍历代码(单独显示每个子键),将得到:

Hobby:

Subkey 1 value = Hobby025

Subkey 2 value = Hobby003

Subkey 3 value = Hobby010

这与上述相同名称的复选框的情况相同。事实上可以认为一个SELECT列表是一列复选框的列表供选择(不是选中)相应的条目。

然而,列表框也有指定的值,假如在<OPTION>标记中设置VALUE属性,将得到的是选择的选项的文本内容,Request.Form集将包含这样一个项目:

Hobby = Swimming, Reading, Sleeping

并且,同样,复杂一些的集合遍历代码将返回如下结果:

Hobby:

Subkey 1 value = Swimming

Subkey 2 value = Reading

Subkey 3 value = Sleeping

当然,假如单个项目被选择,且在<OPTION>中提供了VALUE属性,得到结果包含的仅是:

Hobby = Hobby025

如果没有提供VALUE属性,得到:

Hobby = Swimming

这允许既可以缺省(即无VALUE)显示选项文本,也可做相应的改变。后一种情况在某些情况下是极为有用的,如要显示(一个说明的字符串)和传递一个完全不同的内容(如用一个短码代表一个说明性的字符串)。

d) HTML提交和图像控件

复选框和单选框是布尔型控件的例子,选中或选择返回的为“on”,不像文本框和大多数其他的HTML控件,浏览器不包含没有选中或没有选择的控件的值。

还有另外一种常用的布尔型控件,称为HTML按钮。如<INPUT TYPE=”SUBMIT”>、<INPUT TYPE=”RESET”>、<INPUT TYPE=”IMAGE”>、<INPUT TYPE=”BUTTON”>和<BUTTON>...</BUTTON>类型。

BUTTON类型的控件不返回任何值,因其对窗体没有直接的影响。即使使用用来调用窗体的Submit方法,浏览器在任何请求中将不包含BUTTON类型控件的值。同样,一个<INPUT TYPE=”RESET”>按钮的值也决不会发往服务器。

然而,输入按钮控件SUBMIT和IMAGE类型实际提交窗体给服务器,其VALUE属性包含窗体的其他控件的值(只要在HTML定义中包含一个NAME属性)。例如,这个窗体可能是向导类型Web应用程序的一部分,允许用户一步步进行或取消进程:

<FORM ACTION=”show_request.asp” METHOD=”POST”>

<INPUT TYPE=”SUBMIT” NAME=”btnSubmit” VALUE=”Next”>

<INPUT TYPE=”SUBMIT” NAME=”btnSubmit” VALUE=”Previous”>

<INPUT TYPE=”SUBIMT” NAME=”btnSubmit” VALUE=”Cancel”>

</FORM>

在一个窗体中,可以包括多个SUBMIT按钮。在这种情况下,应该给每一个按钮唯一的VALUE属性,如上所示。当一个窗体被提交时,遍历Request.Form集合的值,将产生一个值,这个值依赖于按下哪个按钮用于提交这个窗体。假如用户按下的“Previous”按钮,将得到:

btnSubmit = Previous

因此,可查询Request.Form集合来决定下一个显示的页面,例如:

Select Case Request.Form(“btnSubmit”)

Case “Next”

Response.Redirect “page_3.asp”

Case “Previous”

Response.Redirect “page_1.a

[1] [2] 下一页

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有