【Asp.net精品源码栏目提醒】:网学会员鉴于大家对Asp.net精品源码十分关注,论文会员在此为大家搜集整理了“【精品】ASP的Form集合 - 大学课件”一文,供大家参考学习
ASP 的 Form 集合FirstName:LastName: 可通过访问 ASP 的 Form 集合来访问其控件内的值:strFirstName Request.Form“FirstName”strLastName Request.Form“LastName” 也可使用窗体中控件的整型索引,索引的范围从在 HTML 中第一个定义的控件开始,然后根据定义的顺序排序:strFirstName Request.Form1strLastName Request.Form2 然而,后面的这种以整型为索引的技术不推荐使用,因为一旦有 HTML 中的控件发生了变化,或者插入一个新的控件,则 ASP 代码将得到错误的值。
进一步而言,对于阅读代码的人来讲,极容易混淆。
1 访问集合的全部值 可以通过引用集合把整个 Form 上的一系列值变成单个的字符变量,且不用提供键或索引。
StrAllFormContent Request.Form 假如文本框包含值 Priscilla 和 Descartes,则 Request.Form 语句将返回下列字符:FirstNamePriscillaLastNameDescartes 注意,提供的值是以名称/值对的形式出现的(即控件名称控件值),并且每一对名称/值相互之间是用符号“”相分隔的。
假如打算把窗体中的内容传递单独的,希望得到值的标准格式的可执行应用程序或 DLL,这个技术是很有用的。
然而,一般说来,都是通过以窗体中控件的名称为文本键来访问集合中的内容。
2 遍历一个 ASP 集合 有两种方式遍历一个 ASP 集合中的所有成员,方式与普通 VB 集合的基本相同。
每个集合提供一个 Count 属性,返回的是集合中条目数量。
可通过使用一个整型索引使用 Count 属性来遍历。
For intLoop1 To Request.Form.CountResponse.Write Request.FormintLoop “”Next 假如先前的窗体包含 Priscilla 和 Descartes 值的两个文本框,将得到如下结果:PriscillaDescartes 然而,更好的方法是使用 For Each...Next 结构。
For Each objItem In Request.FormResponse.Write objItem “” Request.FormobjItem “”Next 这带来的好处是既可以访问控件的名称又可访问其值。
上述代码将得到如下结果:FirstName PriscillaLastName Descartes 注意,一些浏览器返回到 ASP 的值可能与页面上显示的顺序不尽相同。
3 集合成员的多值性 在某些情况下,ASP 集合中的各个成员可能不止一个值,这种情况发生在HTML 定义中有几个控件有相同 Name 属性时。
例如: 在 Form 集合中,将为“OtherHobby”创建一个条目。
然而,它将包括从三个文本框中得到的值。
假如在提交时,用户留下了一个或多个为空,则返回的值为空字符串。
假如用户在第一和第三个文本框分别输入 Gardening 和Mountaineering,第二个文本框为空,在我们的 ASP 代码中访问Request.Form“OtherHobby”,将返回字符串:Gardening Mountaineering 为了能够在这种情况下,访问单个值,可以用复杂一些的代码:For Each objItem In Request.Form If Request.FormobjItem.Count 1 Then ‘More than one value in thisitem Response.Write objItem “:” For intLoop 1 To Request.FormobjItem.Count Response.Write “Subkey” intLoop “value “Request.FormobjItem intLoop “” Next Else Response.Write objItem “ ” Request.FormobjItem “” End IfNext 对于前面的包含三个 OtherHobby 控件的窗体实例,这将返回:OtherHobby:Subkey 1 value GardeningSubkey 2 value Subkey 3 value Mountaineering 然而,由于很少给多个文本框相同的名字,因此这种技术很少用到。
a HTML 中的单选或选页按钮控件 在 HTML 中,需要给几个控件相同的 Name 属性的情况是单选(或选项)按钮,例如:I live in:AmericaEuropeAsia 因为用户只能选择多项中的一个(这就是给它们相同的名字的原因),将仅得到一个返回值,浏览器只能发送所选择控件的值。
因此,假如这个窗体的用户已经选择了“Europez”,将得到这个条目,通过遍历 Form 集得到其值:Country EU 由于为每个控件提供了不同的 VALUE 属性,反映了每个条目所对应的国家或地区的名称。
假如省略了 VALUE 属性,浏览器将返回的值为“on”,因此将得到:Country on 这是不经常用到的,因此一般对使用相同名称的单选控件使用 VALUE 属性。
b HTML 复选框控件 当一个窗体中 HTML
源码包含一个复选框控件时,一般都给定唯一的名称,例如:I enjoy: Reading Eating Sleeping 在这种情况下,提交窗体时,假如仅是第一和第三个复选框被选中(加标记),遍历 Form 集合时,会得到下列值:Reading onSleeping on 然而,假如为每个复选框提供一个值,把这个值发往服务器代替字符串“on”。
例如窗体如下:I enjoy:_Swimming_ReadingEatingSleeping 如果除第三个复选框外,全部提交,在 Request.Form 集合会产生下列结果:Hobby Hobby025 Hobby003 Hobby010 假如编写更复杂一些集合遍历代码,如先前所述(单独显示每个子键),就得到这样结果:Hobby:Subkey 1 value Hobby025Subkey 2 value Hobby003Subkey 3 value Hobby010 需要注意的是两种情况,没有选中的控件根本不返回任何值。
在第一种情况的结果里,没有欺骗性的逗号,第二种情况也没有空值。
这与上述的使用文本框的相当的测试的结果不一样。
使用文本框时,每个文本框都返回一个值,即使是一个空字符串。
这是浏览器造成这样的结果。
因此在 ASP 代码中访问集合时,要注意这个问题。
上述情况一个棘手的负作用是使用复选框时,复选框值的索引与在原始的HTML 中控件的位置没有任何联系,在上述的例子中第四个复选框的子键数为 3,因为当窗体提交时,第二个控件没有选中。
c HTML 列表控件 HTML 中的标记用来产生标准的下拉列表框,其值以一种有趣的混合方式表示。
下列的窗体创建了包含 5 个值可供用户选择,由于包含了 MULTIPLE属性,因此可以通过选择时按下 Shift 或 Ctrl 键,选择不仅一个的条目。
ProgrammingSwimmingReadingEatingSleeping 这种特殊的情况返回的是在 Form 集合中单个条目,它包含选择的值(单个的标记中指定的 VALUE 属性),用逗号分隔:Hobby Hobby025 Hobby003 Hobby010 假如使用更加复杂一些的集合遍历代码(单独显示每个子键),将得到:Hobby:Subkey 1 value Hobby025Subkey 2 value Hobby003Subkey 3 value Hobby010 这与上述相同名称的复选框的情况相同。
事实上可以认为一个 SELECT 列表是一列复选框的列表供选择(不是选中)相应的条目。
然而,列表框也有指定的值,假如在标记中设置 VALUE 属性,将得到的是选择的选项的文本内容,Request.Form 集将包含这样一个项目:Hobby Swimming Reading Sleeping 并且,同样,复杂一些的集合遍历代码将返回如下结果:Hobby:Subkey 1 value SwimmingSubkey 2 value ReadingSubkey 3 value Sleeping 当然,假如单个项目被选择,且在中提供了 VALUE 属性,得到结果包含的仅是:Hobby Hobby025 如果没有提供 VALUE 属性,得到:Hobby Swimming 这允许既可以缺省(即无 VALUE)显示选项文本,也可做相应的改变。
后一种情况在某些情况下是极为有用的,如要显示(一个说明的字符串)和传递一个完全不同的内容(如用一个短码代表一个说明性的字符串)。
d HTML 提交和图像控件 复选框和单选框是布尔型控件的例子,选中或选择返回的为“on”,不像文本框和大多数其他的 HTML 控件,浏览器不包含没有选中或没有选择的控件的值。
还有另外一种常用的布尔型控件,称为 HTML 按钮。
如、、、和...类型。
BUTTON 类型的控件不返回任何值,因其对窗体没有直接的影响。
即使使用用来调用窗体的 Submit 方法,浏览器在任何请求中将不包含 BUTTON 类型控件的值。
同样,一个按钮的值也决不会发往服务器。
然而, 其 输入按钮控件 SUBMIT 和 IMAGE 类型实际提交窗体给服务器, VALUE属性包含窗体的其他控件的值 。
(只要在 HTML 定义中包含一个 NAME 属性) 例如,这个窗体可能是向导类型 Web 应用程序的一部分,允许用户一步步进行或取消进程: 在一个窗体中,可以包括多个 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.asp”Case “Cancel”Response.Redirect “main_menu.asp”End Select 同时,也可根据需要对每个按钮使用不同的 NAME 属性。
且选择其值包含在Form 集合中的控件名称。
在控件没有一个完整的标记而是随后跟着较长的文本标签的情况下,极为有用,如下图所示。
此屏幕上的界面由下列代码产生:What do you want to do now Go on the next page GO back to theprevious page Cancel and go backto the main menu page 在 ASP 页面中,接收到数据后,可以检查按扭名称提供的值来判断按下的是哪个按钮。
If LenRequest.Form“btnNext” Then Response.Redirect “page_3.asp”If LenRequest.Form“btnPrevious” Then Response.Redirect“page_1.asp”If LenRequest.Form“btnCancel” Then Response.Redirect“main_menu.asp” 这个工作是查询一个键上的 ASP 集合,如果不存在则返回一个空的字符串。
换句话说, 如果第二个按钮 )按 则 (previous 页 下 , Request.Form“btnNext”的值是一个空字符串,则其长度为零而不至于产生一个错误。
当第二个按钮按下时,则在 Form 集合中这个条目的值 Request.Form(“btnPrevious”),将是“ ”其长度大于零。
e 提高使用 Request 集合的效率 访问一个 ASP 集合来下载一个值是费时的需计算资源的过程,因为这个操作包含了一系列对相关集合的搜索,这比访问一个局部变量要慢得多。
因此,如果打算在页面中多次使用集合中的一个值,应该考虑将其存贮成为一个局部变量,例如:strTitle Request.Form“Title”strFirstName Request.Form“FirstName”strLastName Request.Form“LastName”If LenstTitle Then strTitle strTitle “ “If strFirstName “ “ ThenStrFullName strTitle “ “ strLastNameElseIf LenstrFirstName 1 ThenStrFullName strTitle strFirstName “ “ strLastNameElseStrFullName strTitle strFirstName “ ” strLastNameEnd If f 搜索所有的 Request 集合 在某些情况下,可能知道一个值的键名将出现在 Request 集合中,但不能准确地知道是哪一个集合。
例如,假如有几个页面(或一个页面的不同段)发送一个值给同一个 ASP 脚本,它可能在 Form 或者 QueryString 集合中出现。
要看一下一个值为什么可能出现在不同的集合中,考虑一下这种情况:使用了超级链接元素请求一个页面。
在这种情况下,增加一个值到请求的唯一方法是把它加到 URL 上。
然而,同样的值可能已出现在另一个页面的中,或同一页面不同部分:.........For help go to the Help Page... 在这种情况下,按下窗体上的 Help 按钮,将发送 Request.Form 集合中一对名称/值“pageHelp”。
然而,按下超级链接也可能发送名称/值“PageHelp”,但是这次却是在 QueryString 集合里。
为访问这个值,可使用ASP Request 对象的一个特殊功能:strPage Request“page” 这将按序搜索全部的集合——QueryString、Form、Cookies、ClientCertificate、ServerVariables,直到发现第一个匹配值的名称。
这样做比直接访问适当的集合效率低,并且是不安全的,除非能绝对保证这个值不会出现在另外一个集合中。
例如,可能希望搜集满足客户请求的 Web 服务器的名称,这通过出现在每个查询中的 Request.ServerVariables 集合中寻找“SERVER_NAME”来实现。
然而,假如任一其他的集合也包含名为“server_name”的值(记住键名不区分大小写),当使用 Request“server_name”时,得到的是错误的结果。
使用Reqeust.ServerVariables“server_name”句法,我们将很难进行错误追踪。
总而言之,使用“搜索全部集合”技术要格外小心,且只在没有其他技术能够提供你需要的结果时使用。
g 访问其他的集合 本文的这一节里,已经集中讨论了 Form 集合,这可能是使用得最多的一个。
然而,所有这些技术同样适用于其他的对象。
包括那些由 Request 对象提供的(即Form、QueryString、Cookies、ServerVariables 和 ClientCertificate)集合,及由 Response 对象提供的 cookies(及其他对象提供的集合)。
我们将简短了解一个值如何进入一个 QueryString 集合,及其优点和不足。
然而,同时这两个 Cookies 集合有额外的功能,可以使使用 cookie 更加方便,下面讨论这个内容
上一篇:
【精品】ASP可视化编程及应用课件
下一篇:
企业管理论文:电力企业管理中的绩效考核工作