PEAR之HTML_QuickForm的尝试

如果对于我们PHP的爱好者来说,最大的希望就是能让PHP更加胜任大系统的架构.
直到有一天,企业级的解决方案都会考虑选择的PHP的框架体系.

然而,我们不得不承认,PHP先天的脚本属性使得这样的理想比较奢侈.但是,努力一定会有所收获.

PEAR::HTML_QuickForm
这个公共包让我们的代码更加纯洁,不再是HTML和脚本稀里糊涂的搅在一起.然而他更大的功能我们非常有必要去发掘.
毫无疑问,他的直接功能就是快速构建Form.
1.构建
代码1:
 require_once("HTML/QuickForm.php");
 //建立一个表单对象,表单名,表单提交方式
 $form = new HTML_QuickForm('fmJyxx','post');
 //表单增加一个标题
 $form->addElement('header', 'title','标题');
 //表单增加一个select控件,名称叫做field1,Label为字段1,下拉列表有两个可选值s1和s2,Value对应"1"和"2"
 $form->addElement('select', 'field1', '字段1:',array("1"=>"s1","2"=>"s2"));
 //表单增加一个Text控件.
 $form->addElement('text', 'field2', '字段2:');
 
 //以上的通过增加的Element根据默认的模板为上下排列,下面我们把两个按钮排列成一行添加进去
 $group[] =& HTML_QuickForm::createElement('submit', 'tj', '提交');
 $group[] =& HTML_QuickForm::createElement('reset', 'cz', '重置');
 $form->addGroup($group, 'buttons', '功能按钮:', ' ');

通过上面的代码我们的表单就构造好了,通过$form->display().就显示了出来,看我们的PHP慢慢的把HTML标签从我们的Coding中淡化了,我们象写Java,C++代码一样专注于逻辑的编写,而不是标签的[排列了.

QuickForm还提供了对控件数据的验证功能,验证的规则很丰富,也可以支持扩展,例如你要求字段2必录,
$form->addRule("field2","字段2 不能为空",'required','','client');
参数分别为:要求的控件名,验证不通过的提示信息,规则名称(此为比录),client表示可以把规则转化为客户端的javascript代码.

例如有一个字段3,你需要对该字段有自己的特殊规则,可以这么做:
注册一个规则
$form->registerRule('ckdate','function','mycheckdate');
参数:规则名称,规则验证方式为函数,函数名称mycheckdate
那么你只要定义mycheckdate函数就可以了,系统会自动传递字段3的值作为该函数的参数,象这样
function mycheckdate($val){
}
返回true或false表示你对该值的验证结果.

2.使用
上面我们把构建一个Form的方法了解了,但是构建完之后我们如何来控制这些控件.
QuickForm是一个体系,提供了HTML_QuickForm_Element类他是所有控件的基类,通过继承这个基类,我们有所有支持的控件的具体类,比如HTML_QuickForm_Select.每个具象类都有自己不同的属性和不同的操作方法,比如Text只需要getValue和setValue,而Select却需要有对Options的控制,如addOption函数.
在完成上述代码之后,我们可以这样来控制某个控件
$elem = $form->getElement("elementname");
得到的$elem就是对名称为"elementname"的控件的引用指针,通过这个指针,你可以对该具体类的属性进行存取.每个控件都有自己对应的类,相信信息请参考Pear's Manual的HTML_QuickForm部分.
(注:我在尝试这一部分的时候,遇到失灵的现象,还盼早日知道详情.)

3.和身份验证一起使用
我们常用的身份验证需要一个包含输入用户名和密码的Form,而这个Form可以由QuickForm构建,而认证方式可以通过另外一个Pear的package--Auth来完成.

代码2:
 //构建用户名和密码的Form代码就采用上述的QuickForm构建,包含在函数show_form中,在此省略
 //...........
 //该验证方式基于数据库验证,在下面的例子中,数据库为本地的mysql下的mydb,
 //创建的关系表为Auth,里面的字段为username和password,密码加密方法为"none"表示密码没有加密
 require_once("AUTH/AUTH.php");
 //连接参数
 $options = array(
  "dsn" => "mysql://caoxh:jiziba@localhost/mydb",
  "table" => "auth",
  "usernamecol" => "username", //用户名字段
  "passwordcol" => "password", //口令字段
  "cryptType" => "none",       //口令加密方式,明文验证则'none'
 );
 
 //全局的认证变量
 $au = new Auth('DB',$options,'show_form');
 $au->setExpire(10);
 $auth->start();
 if(!$auth->getAuth()){
  exit('system deny the user!');
 }
Auth会把Form显示出来并进行认证,把$au作为全局变量,你从此就可以通过$au的方法来判断认证信息.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值