我上下搜索但找不到哪一个更好的Phalcon\Tag或Phalcon\Forms来创建表单.
这两个类都具有创建表单元素的功能.但我发现Phalcon\Tag中有一些方便的标签,例如Phalcon\Tag :: emailField()或Phalcon\Tag :: dateField(array())
Phalcon文档说:
" Phalcon\Forms是一个帮助开发人员创建和维护Web应用程序中表单的组件. "
" Phalcon\Tag旨在简化HTML标记的构建.它提供了一组帮助程序,以动态方式生成HTML. "
任何人都可以帮助我使用这两种方法的利弊.
谢谢
简单来说,Phalcon\Tag用于设计html(用户视图).但是为了验证&&向表单添加规则,您需要使用phalcon\forms我将在下面向您展示phalcon\forums的示例
新表格类别:
use Phalcon\Forms\Form,
Phalcon\Forms\Element\Password,
Phalcon\Forms\Element\Email as Emailfield,
Phalcon\Forms\Element\Check,
Phalcon\Forms\Element\Hidden,
Phalcon\Validation\Validator\PresenceOf,
Phalcon\Validation\Validator\Identical,
Phalcon\Validation\Validator\Email;
class LoginForm extends Form
{
public function initialize()
{
$email = new Emailfield('email', array(
'placeholder' => 'Type your Email'
));
$email->setLabel('E-Mail');
$email->setFilters('email');
$email->addValidators(array(
new PresenceOf(array(
'message' => 'E-mail is required'
)),
new Email(array(
'message' => 'E-mail is not valid'
))
));
$this->add($email);
$password = new Password('password', array(
'placeholder' => 'Type your Password'
));
$password->setLabel('Password');
$password->setFilters(array('striptags', 'string'));
$password->addValidators(array(
new PresenceOf(array(
'message' => 'Password required'
))
));
$this->add($password);
//Remember
$long_login = new Check('long_login', array(
'value' => 'yes'
));
$long_login->setLabel('Keep me logged in');
$this->add($long_login);
// CSRF
$csrf = new Hidden('csrf');
$csrf->addValidator(new Identical(array(
'value' => $this->security->getSessionToken(),
'message' => 'CSRF validation failed'
)));
// $this->add($csrf);
}
}
Run Code Online (Sandbox Code Playgroud)
在控制器中:
$form = new LoginForm();
if (!empty($_POST)) {
if (!$form->isValid($_POST)) {
$errors = array();
foreach ($form->getMessages() as $message) {
$errors[] = $message;
}
if (!empty($errors))
$this->flash->error(join('<br/>', $errors));
} else {
//Login Continues
}
}
$this->view->setVar('form', $form);
Run Code Online (Sandbox Code Playgroud)
要将此表单转换为html,请输入以下代码:
<div class="form-group">
{{ form.label('email',['class': 'control-label']) }}
{{ form.render('email', ['class': 'form-control input-md']) }}
</div>
<div class="form-group">
{{ form.label('password',['class': 'control-label']) }}
{{ form.render('password', ['class': 'form-control input-md']) }}
</div>
<div class="checkbox">
{{ form.render('long_login') }}
{{ form.label('long_login') }}
</div>
Run Code Online (Sandbox Code Playgroud)