PEAR::HTML_QuickForm入门一

1 篇文章 0 订阅

 相信每个PHP程序员都知道PEAR,而PEAR::HTML_QuickForm是PEAR中的一个非常实用的类库,它可以让你动态地创建,验证和显示HTML表单。

主要特点如下:

* 可以创建20种常见的表单;
* 生成兼容性好的XHTML代码
* 提供强大和可扩展的表单验证功能
* 自动化的服务器端验证和过滤
* 可以生成客户端验证代码(JavaScript)。
* 支持文件上传功能 * 支持自定义的表单显示方法
* 支持多种模板引擎,如ITX, Sigma, Flexy, Smarty等
* 可加入自定义的表单元素、验证规则和显示规则。

下载和安装请参看
http://pear.php.net

 

创建表单

      

首先我们来看这样一个例子:

FirstForm.php

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> PEAR::HTML_QuickForm </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="Haohappy">
</HEAD>
<BODY>
<?
require_once("HTML/QuickForm.php");

//建立一个表单对象
$form = new HTML_QuickForm('frmTest', 'post');

 

/*利用该对象的addElement方法增加四个表单元素

addElemment()的三个参数分别表示类型、名称、显示的文字。

*/
$form->addElement('header', 'header', '请登录');
$form->addElement('text', 'name', '用户名:');
$form->addElement('password', 'password', '密码:');
$form->addElement('submit', 'submit', '提交');

//输出到浏览器
$form->display();
?>     
</BODY>
</HTML>

 

输出效果如图:       

 

 

这种方法看起来是不是很酷 J 我们可以快速地创建表单,当然这不是我们使用QuickForm的主要原因,因为使用一些可视化的工具来创建表单似乎更快一些。

 

QuickForm可以创建的表单元素类型:

 

text

autocomplete

password

textarea

hidden

select

hierselect

hiddenselect

checkbox

radio

submit

reset

button

image

file

advcheckbox

date

static

header

link

html


 

处理表单数据

接下来我们加入对表单的处理功能。

 

Form2.php

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> PEAR::HTML_QuickForm </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="Haohappy">
</HEAD>

<BODY>
<?
require_once("HTML/QuickForm.php");
$form = new HTML_QuickForm('frmTest', 'post');
$form->addElement('header', 'header', '请登录');
$form->addElement('text', 'name', '用户名:');
$form->addElement('password', 'password', '密码:');
$form->addElement('submit', '', '提交');

if (
$form->validate()) {
    
$form->process('say_hello');
} else {
    
$form->display();
}

function
say_hello($data) {
    print
'Hello, ' . $data['name'];
    print
'<BR>';
    print
'Your password is '.$data['password'];
}

?>
    
</BODY>
</HTML>

 

效果:

 

点击提交按钮后

 

 

在这段代码里,我们设计了一个say_hello()函数来处理表单,并通过$form->process()来调用。

输入到表单的数据保存在一个$data数组中,可以传递给say_hello()函数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值