如果对于我们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的方法来判断认证信息.

|