结合PHP使用HTML表单(3)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 
令人惊奇的消失的复选框

复选框只有实际被选中时才被提交,认识到这一点很重要。否则,它的消失将告诉您所需知道的实情:用户没有单击复选框。使用复选框时,您可以使用 isset() 函数显式地检查是否设置了值:


清单 7. 检查是否提交了复选框

...

$contact_value = $HTTP_GET_VARS['contact'];

echo $contact_value;

if (isset($contact_value)) {

  //The checkbox was clicked

} else {

  //The checkbox wasn't clicked

}

...

 

获取所有表单值

复选框字段只是您对预期表单值名称可能不完全有把握的情形的示例之一。通常,您会发现有一个以通用方法访问所有表单值的例程是很有用的。

幸运的是,因为 $HTTP_GET_VARS及其同类只是散列表,您可以用数组的一些特性来操作它们。例如,您可以使用 array_keys() 函数来获取所有潜在值名称的列表:


清单 8. 获取表单值名称的列表

...

$form_fields = array_keys($HTTP_GET_VARS);

for ($i = 0; $i < sizeof($form_fields); $i++) {

    $thisField = $form_fields[$i];

    $thisValue = $HTTP_GET_VARS[$thisField];

    echo $thisField ." = ". $thisValue;

    echo "<br />"; 

}

...

在本例中,您实际上结合了几种技术。首先,检索表单字段名称的数组并将其命名为 $form_fields。$form_fields 数组只是一个典型的数组,因此您可以使用 sizeof() 函数来确定潜在键的数目,并对每一项进行循环遍历。对于每一项,检索字段的名称然后使用该名称获取实际值。生成的 Web 页面看起来如下:


ship = Midnight Runner

tripdate = <?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />12-15-2433

exploration = yes

crew = Array

这里有两个重要事项。第一,contact 字段根本没有返回值,这正如预期的那样。第二,crew 值(顺便说一下,您或许知道:它的名称是 crew 而不是 crew[])是一个数组而不是值。为了实际检索所有值,需要使用 is_array() 函数检测所有数组并相应地处理它们:


清单 9. 处理数组

...

for ($i = 0; $i < sizeof($form_fields); $i++) {

    $thisField = $form_fields[$i];

    $thisValue = $HTTP_GET_VARS[$thisField];

    if (is_array($thisValue)){

        for ($j = 0; $j < sizeof($thisValue); $j++) {

            echo $thisField ." = ". $thisValue[$j];

            echo "<br />";

        }

    } else {

        echo $thisField ." = ". $thisValue;

    }

    echo "<br />"; 

}

...

结果是所有已实际提交的数据:


ship = Midnight Runner

tripdate = 12-15-2433

exploration = yes

crew = snertal

crew = gosny

最后一个说明:点

既然您有了能适应您提交任何表单值的表单操作页面,您就需要抽一点时间考虑一个常常让 PHP 程序员感到意外的情形。

有些情况下,设计人员会选择使用一个图形按钮而不是提交按钮,图形按钮如图 2 所示,代码如清单 10 所示。


清单 10. 添加图形按钮

...

        <tr>

           <td valign="top">Crew species:  </td>

           <td>

               <select name="crew[]" multiple="multiple">

                   <option value="xebrax">Xebrax</option>

                   <option value="snertal">Snertal</option>

                   <option value="gosny">Gosny</option>

               </select>

           </td>

        </tr>

        <tr>

           <td colspan="2" align="center">

              <input type="image" src="button.gif" name="formbutton"/>

           </td>

        </tr>

    </table>

...

 

<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />

 

图 2. 表单上的图形按钮

请注意,尽管上图中只有一个图像,却有两个图形按钮(或期望的结果)。作为开发人员,您可以通过检查和值一同返回的 x 和 y 坐标知道用户单击了何处。事实上,按原样提交该表单可能会创建以如下所示结尾的 URL 和查询字符串:


...snertal&crew%5B%5D=gosny&formbutton.x=37&formbutton.y=14

请注意附加到按钮名称的 .x 和 .y。然而,如果您打算提交该页面然后查看结果,您会看到:


ship = Midnight Runner

tripdate = 12-15-2433

exploration = yes

crew = snertal

crew = gosny

formbutton_x = 37

formbutton_y = 14

请注意,点号(.)已被转换成下划线(_)。这似乎有点奇怪,但它是必要的,因为 PHP 中的变量名不能有点号,因此 $formbutton.x 会是一个非法变量名。事实上,表单名称中的任何点号 — 不仅仅针对图像按钮 — 都被转换成下划线。

结束语

在本文中,您看到了对用户通过HTML或XHTML表单提交的信息进行访问的几种方法。如何处理该信息取决于您使用的PHP版本和您是否能将表单变量作为全局变量进行访问。无论何种情况,表单值可作为数组使用,并且您可以用数组的特性来循环遍历所有可用的值。

时间: 2024-11-01 00:13:04

结合PHP使用HTML表单(3)的相关文章

WEB表单设计

设计师不再只是为互联网创造漂亮美观的图形那么简单了,作为一个WEB设计师,我们还需要考虑一些其他的问题,比如用户体验,算法,代码等等.如今用户体验设计越来越重要,对于WEB表单的设计尤其如此. WEB表单设计的目标是设计出一套让用户能够从填表到点击提交按钮的最简单的流程.这个过程中不需要太多的炫目效果,虽然jQuery的表单插件一直都很受欢迎.在这片文章中我们只关注于表单的用户体验和交互过程.这里的概念也能够有效的帮助你减少用户在填表过程中的挫折感. 保持醒目和简洁 我听过不计其数的用户抱怨注册

在ASP中使用SQL语句之9:表单操作

语句 从某个页面表单中取出信息是ASP编程中常见的问题.但是,遍历通过表单传递的记录会花去多长时间呢?这取决于数据库的大小.简单的GUI界面都可能令循环遍历操作耗费太多的时间. 比方说,假设有个团队成员登录到GUI屏幕输入自己的名字姓氏和名字之间用点号连接:amy.cowen.这个值通过表单提交,她的当前项目列表就从数据库中取了出来并显示在屏幕上.为了快速地取出用户的记录以便显示在屏幕上,你可以编写以下代码. 假设HTML页面上包含以下代码:<FORM ACTION="login_post

《PHP编程最快明白》第四讲:日期、表单接收、session、cookie

实例11:日期戳.日期显示 复制代码 代码如下: <?php echo time();//返回一串以秒计算的时间数字戳 echo "<br>"; echo date("Y-m-d H:i:s",time()+8*3600);//格式化时间,+8*3600变为中国时区时间 echo "<br>"; $str="2010-08-24 10:26:10"; echo date("Y-m-d H

表单-多表头和可变表头(一条信息的数据量大小可变。)该怎么设计数据库的表结构。

问题描述 多表头和可变表头(一条信息的数据量大小可变.)该怎么设计数据库的表结构. 我现在有一个表单需要存入数据库.但是客户要求该表单的 表头可变.也就是他要自定义表单.这种情况我该怎么为这张表单设计表结构了?同时该表单中的所有字段都要参加计算的,有些项的值是其他项通过计算得出的.虽然是简单的加减乘除,但是客户要求可以自动的计算.小弟用的Spring MVC+JPA 数据库mysql 或者 oracle 解决方案 一般一个表单中的字段分为固定的字段和 动态的字段. 将固定的字段,设计成一张表,称

聊聊打造优质WEB表单的9个方法

  这篇文章算是笔者交的一份读书笔记,与 CRM 系统打交道了这么久,表单天天见.如果表单有感情的话,我猜它应该都不想再看见我了.也是有缘,老板推荐了一本表单设计的书--<Web Form Design – Filling the blanks>by Luke Wroblewski,得此书如获至宝.该书对表单描述详尽,案例充分,解决了许多笔者多年未解决的问题.接下来进入正题,我们来聊一聊如何打造优质 Web 表单.黑喂狗! 1. 标签推荐使用右对齐方式 (图示1:淘宝网注册页面) 马泰奥·彭佐

用了城市级联插件,表单序列化后选择的城市变成乱码

问题描述 用了城市级联插件,表单序列化后选择的城市变成乱码 明明选择是北京,但是序列化后变成了如下所示 province=%E5%8C%97%E4%BA%AC%E5%B8%82&city=%E6%98%8C%E5%B9%B3%E5%8C%B 求指点 解决方案 这个是中文的编码,不是乱码..你的内容不止北京这2个字而已吧,北京对应的编码应该是%E5%8C%97%E4%BA%AC,你的多了一个字了. document.write(encodeURIComponent('北京')); 你服务器正确获取

Struts2框架,表单请求到action出错,貌似找不到自定义action类中的方法。

问题描述 Struts2框架,表单请求到action出错,貌似找不到自定义action类中的方法. 关键代码如下: ${Msg.sendUser.username } 上面代码的意思是:把${Msg.sendUser}提交到action,赋值给 action类属性message的sendUser.(sendUser数据类型是User对象) 请求后提示找不到action中的自定义方法,但是我表单中的值换成下面 的,变成赋值给message的属性sendUser的属性username,就能成功. 是

Ajax表单提交实例

ajax|表单提交 昨天在CSDN逛的时候,看见一位网友需要解决一些关于AJAX的FORM提交的问题,现在把一个实例贴出来,希望对广大爱好者有帮助. <!--注册模块-->default.asp <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><

JSP动态网页入门:表单输入例子

js|动态|网页 我们将创建一个Web页面,它有一个输入表单,用户可以输入一个股票代号以获得出当前股票价格(有20分钟延迟).如果输入有误,则显示错误提示页面. quote.jsp 首先,用以下代码创建quote.jsp页面并将其保存在JSWDK安装目录下的Web 目录中.大多数的页面是含JSP代码的标准HTML.第六行是一个页面指令,表明将把所有错误发送到"errorPage.jsp"文中.第13到15行是一个脚本段,主要说明仅当有"symbol"参数时才显示表格

一种表单重复提交处理方法

表单重复提交处理: 1. 在生成表单时执行如下:    session.setAttribute("forum_add", "forum_add"); 2. 提交处理时作如下判断         if (isRedo(request, "forum_add")) {            //提示重复提交,作相关处理        } 相关函数:     /**     * 判断是否为重复提交     * 1,检查Session中是否含有指定名字