PEAR::HTML_QuickForm入门二

 表单数据验证

我们再次对这段代码进行改进,为其加入表单数据验证功能

使用户在登录时必须输入用户名和密码,并且用户名长度不能小于三位。

 

Form3.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', '', '提交');

//加入三条验证规则
$form->addRule('name','用户名不能为空!', 'required');
$form->addRule('name','用户名必须为3位以上字母或数字', 'minlength',3);
$form->addRule('password','密码不能为空!', 'required');

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>

 

输出效果如图:

 

 

 

 

可以看到我们仅用了以下三行简单的代码来实现数据验证功能,和我们平时所采取的方法相比方便得多。

//加入三条验证规则
$form->addRule('name','用户名不能为空!', 'required');
$form->addRule('name','用户名必须为3位以上字母或数字', 'minlength',3);
$form->addRule('password','密码不能为空!', 'required');

 

addRule()方法的四个参数分别表示规则应用的对象、提醒文字、验证规则的类型(required表示必须输入,不能为空)、验证规则的参数。

 

PEAR::HTML_QuickForm自带的验证规则如下:

规则名称

参数

规则描述

required

 

必须输入,不能为空

maxlength

$length

最大字符长度

minlength

$length

最小字符长度

rangelength

$min,$max

字符长度的范围

regex

$rx

输入的数据必须匹配给定的正则表达式

email

true
(forDNS heck)

验证email地址的格式(有个可选的选项还可以查看域名是否有效)

lettersonly

 

只能是英文字母

alphanumeric

 

只能是英文字母或数字

numeric

 

只能是数字

nopunctuation

 

不能包含以下特殊字符: ( ) . / * ^ ? # ! @ $ % + = , " ' > < ~ [ ] { }.

nonzero

 

不能为零

compare

 

两次输入必须相同

uploadedfile

 

表单元素必须包含正确上传文件

maxfilesize

$size

上传文件的最大容量

mimetype

$mime

上传文件的类型,$mime可以是数组,则上传文件的类型必须为其中一种

filename

$file_rx

上传的文件的名称必须满足给定的正则表达式

 

 

 

 

其中compare规则有点特殊,它是指两个表单的输入数据必须相同(如密码确认时)。它的用法如下:

$form->addElement('password','password_1','Enter your password:');
$form->addElement('password','password_2','Enter your password (again):');
$form->addRule(array('password_1','password_2'),
               
"Passwords don't match!",'compare');

 

compare也可以用来比较两个表单中输入的数据的大小,如:

$form->addElement('text','min_age','Minimum Age:');
$form->addElement('text','max_age','Maximum Age:');
$form->addRule(array('min_age','max_age'),
               
"Minimum Age must be less than Maximum Age",
               
'compare','<');

客户端验证功能

前面有提到使用addRule()来增加一条验证规则,其实addRule()还有第五个参数—client。这个参数用来说明我们将使用的是客户端验证,如果传递了这个参数,则程序会自动生成客户端的Javascript代码来验证表单里的数据。

 

使用客户端验证更加快捷方便,而且可以减轻服务器的负载。

 

Client.php

//加入三条客户端验证规则
$form->addRule('name','用户名不能为空!', 'required','','client');
$form->addRule('name','用户名必须为3位以上字母或数字', 'minlength',3,'client');
$form->addRule('password','密码不能为空!', 'required','','client');

 

效果如图:

 

1

 

2

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值