ASP+JAVAScript:复杂表单的动态生成与验证

时间:2007-10-06 21:51:00 

这里所谓的复杂表单,是指表单中包含多种不同的输入类型,比如下拉列表框、单行文本、多行文本、数值等。在经常需要更换这类表单的场合,需要有一个表单的动态生成程序。本文介绍的正是这样一个系统,它以数据库保存表单定义数据,利用ASP脚本动态生成表单HTML代码以及验证表单输入的脚本。
  一、定义数据库表结构
  在Web上经常可以看到“每周调查”之类的表单,这就是一种需要经常更新的表单。如果有一个动态生成表单及其验证脚本的程序,可以大大减少制作这些表单的工作量。
  在本文的动态表单生成与验证示例中,我们使用一个Access数据库来存储有关表单的定义信息,同时为简单计,用户在表单中输入的数据也保存到同一数据库。定义表单需要两个表:第一个表(Definitons)用于表单输入域的定义,第二个表(Lists)保存各个输入域的附加信息,比如选择列表的选择项。
  表Definitons包含如下字段:
FieldName —— 赋予表单输入域的变量名字
Label —— 即文本标签,显示在输入域前面的提示性文字
Type —— 单个字符,该字符表示表单输入域的形式和输入值的类型
  具体如下:
  (t) 文本输入框,即< INPUT TYPE="TEXT" >。
  (n) 文本输入框,但要求输入数字值。
  (m) 备注型内容,用于注释或其他大量文本的输入,它是一个多行文本编辑框。
  (b) 要求输入“是”或“否”。本实现中将用复选框来获取这种输入,复选框的文本标签为“是”。如果用户选中它,则返回值是“on”。
  (r) 单选按钮。
  (l) 下拉列表框。
  Min —— 仅对数字型输入值有效,在这里给出最小值。在本例中有一个“Age”(年龄)数字型输入框,它的最小值设定为1。
  Max —— 该字段的值与输入域形式有关。对于数字型输入框,它表示的是允许的最大值。例如“Age”的Max值为100。对于文本输入框,Max表示允许的最多字符个数。对于多行文本编辑框,Max表示可见区域的文本行数。
  Required —— 表示是否必须输入。这种类型的值如果没有输入,则输入验证程序将报告错误。在表单中,必须输入的值以星号标记,并以脚注的形式提示用户该类值必须输入。
  本文的示例表单是一个ASP程序员调查表,在Definitons表中该表单的定义主要如下:
  FieldName Label Type Min Max Required
  Name 姓名 文本(t) - 50 否
  Age 年龄 数字(n) 1 100 否
  Sex 性别 单选按钮(r) - - 是
  E-mail 邮件地址 文本(t) - - 是
  Language 编程语言 下拉列表框(l) - - 否
  表Lists用于保存输入域定义的一些附加信息,本例有“Sex”和“Languages”两个输入值要用到它。表Lists非常简单,只包含如下三个字段:
  FieldName —— 当前记录属于哪个表单输入域
  Value —— 选择项的值
  Label —— 用户所看到的选择项的提示文本
  输入域“Sex”只能从两个值选取:“男”或“女”。“Language”列出了几种可应用于ASP环境的编程语言,包括:VBScript,JavaScript,C,Perl和“其他”。
  第三个表“Records”保存用户提交的内容,它也包含三个字段,每个记录对应用户的一次提交:
  Record —— 备注类型,以查询字符串形式保存的用户输入。
  Created —— 用户提交该表单的日期和时间。 RemoteIP —— 表单提交者的IP地址。
  在实际应用中可能要收集更多有关用户的信息,为简单计,本例只记录提交时间和用户IP地址这两个附加信息。

标签:表单,验证,动态
0
投稿

猜你喜欢

  • javascript结合canvas实现图片旋转效果

    2023-08-07 23:47:59
  • Go语言实现socket实例

    2024-02-04 20:17:30
  • Django实现发送邮件功能

    2021-05-13 10:25:44
  • Python的argparse库使用详解

    2023-06-13 11:27:36
  • Python处理mysql特殊字符的问题

    2024-01-17 01:28:38
  • Python re正则表达式元字符分组()用法分享

    2021-05-15 12:31:56
  • MySQL中的回表和索引覆盖示例详解

    2024-01-20 11:37:16
  • Python用dilb提取照片上人脸的示例

    2021-07-04 23:34:47
  • golang组件swagger生成接口文档实践示例

    2023-09-19 11:29:39
  • TensorFlow 合并/连接数组的方法

    2021-08-19 16:28:35
  • vue3中setup-script的应用实例

    2024-04-27 16:01:01
  • SQL Server重温 事务

    2024-01-14 21:47:00
  • 使用Python实现分别输出每个数组

    2021-10-30 00:28:49
  • selenium跳过webdriver检测并模拟登录淘宝

    2023-06-14 18:22:52
  • python使用docx模块读写docx文件的方法与docx模块常用方法详解

    2022-05-14 11:37:17
  • 关于JSON以及JSON在PHP中的应用技巧

    2023-11-16 00:03:38
  • 在javascript中如何取整?

    2009-06-07 18:34:00
  • JavaScript 获取客户端计算机硬件及系统信息

    2009-01-13 17:59:00
  • asp经典入门教程 在ASP中使用SQL 语句

    2013-06-01 20:23:21
  • Django操作cookie的实现

    2023-06-07 17:05:21
  • asp之家 网络编程 m.aspxhome.com