您的位置:首页 > 编程语言 > PHP开发

Yii2 Activefrom表单部分组件

2015-12-20 12:04 597 查看
文本框:textInput();
密码框:passwordInput();
单选框:radio(),radioList();
复选框:checkbox(),checkboxList();
下拉框:dropDownList();
隐藏域:hiddenInput();
文本域:textarea(['rows'=>3]);
文件上传:fileInput();
提交按钮:submitButton();
重置按钮:resetButtun();


<?php
$form = ActiveForm::begin(['action' => ['test/getpost'],'method'=>'post',]); ?>

<? echo $form->field($model, 'username')->textInput(['maxlength' => 20]) ?>

<? echo $form->field($model, 'password')->passwordInput(['maxlength' => 20]) ?>

<? echo $form->field($model, 'sex')->radioList(['1'=>'男','0'=>'女']) ?>

<? echo $form->field($model, 'edu')->dropDownList(['1'=>'大学','2'=>'高中','3'=>'初中'], ['prompt'=>'请选择','style'=>'width:120px']) ?>

<? echo $form->field($model, 'file')->fileInput() ?>

<? echo $form->field($model, 'hobby')->checkboxList(['0'=>'篮球','1'=>'足球','2'=>'羽毛球','3'=>'乒乓球']) ?>

<? echo $form->field($model, 'info')->textarea(['rows'=>3]) ?>

<? echo $form->field($model, 'userid')->hiddenInput(['value'=>3]) ?>

<? echo Html::submitButton('提交', ['class'=>'btn btn-primary','name' =>'submit-button']) ?>

<? echo Html::resetButton('重置', ['class'=>'btn btn-primary','name' =>'submit-button']) ?>

<?php ActiveForm::end(); ?>


1.创建模型

a.加入基类

use yii/base/Model

b.创建类继承自基类

c.创建所需要的变量

e.定义规则

f.注意里面用[]括起来

例如:


<?php

namespace app\models;

use yii\base\Model;

class EntryForm extends Model
{
public $name;
public $email;

public function rules()
{
return [
[['name', 'email'], 'required'],
['email', 'email'],
];
}
}


该类继承自Yii 提供的一个基类
[[yii\base\Model]]
,该基类通常用来表示数据

补充:
[[yii\base\Model]]
被用于普通模型类的父类并与数据表无关。
[[yii\db\ActiveRecord]]
通常是普通模型类的父类但与数据表有关联(译注:
[[yii\db\ActiveRecord]]
类其实也是继承自
[[yii\base\Model]]
,增加了数据库处理)。

EntryForm 类包含 name 和 email 两个公共成员,用来储存用户输入的数据。它还包含一个名为
rules()
的方法,用来返回数据验证规则的集合。上面声明的验证规则表示:

name 和 email 值都是必须的

email 的值必须满足email规则验证

如果你有一个处理用户提交数据的 EntryForm 对象,你可以调用它的
[[yii\base\Model::validate()|validate()]]
方法触发数据验证。如果有数据验证失败,将把
[[yii\base\Model::hasErrors|hasErrors]]
属性设为 ture,想要知道具体发生什么错误就调用
[[yii\base\Model::getErrors|getErrors]]


<?php
$model = new EntryForm();
$model->name = 'Qiang';
$model->email = 'bad';
if ($model->validate()) {
// 验证成功!
} else {
// 失败!
// 使用 $model->getErrors() 获取错误详情
}


2.创建操作

下面你得在 site 控制器中创建一个 entry 操作用于新建的模型。操作的创建和使用已经在说一声你好小节中解释了。

<?php

namespace app\controllers;

use Yii;
use yii\web\Controller;
use app\models\EntryForm;

class SiteController extends Controller
{
// ...其它代码...

public function actionEntry()
{
$model = new EntryForm;

if ($model->load(Yii::$app->request->post()) && $model->validate()) {
// 验证 $model 收到的数据

// 做些有意义的事 ...

return $this->render('entry-confirm', ['model' => $model]);
} else {
// 无论是初始化显示还是数据验证错误
return $this->render('entry', ['model' => $model]);
}
}
}


该操作首先创建了一个 EntryForm 对象。然后尝试从
$_POST
搜集用户提交的数据,由 Yii 的
[[yii\web\Request::post()]]
方法负责搜集。如果模型被成功填充数据(也就是说用户已经提交了 HTML 表单),操作将调用
[[yii\base\Model::validate()|validate()]]
去确保用户提交的是有效数据。

补充:表达式
Yii::$app
代表应用实例,它是一个全局可访问的单例。同时它也是一个服务定位器,能提供request,response,db 等等特定功能的组件。在上面的代码里就是使用 request 组件来访问应用实例收到的
$_POST
数据。

用户提交表单后,操作将会渲染一个名为
entry-confirm
的视图去确认用户输入的数据。如果没填表单就提交,或数据包含错误(译者:如 email 格式不对),entry 视图将会渲染输出,连同表单一起输出的还有验证错误的详细信息。

注意:在这个简单例子里我们只是呈现了有效数据的确认页面。实践中你应该考虑使用
[[yii\web\Controller::refresh()|refresh()]]
[[yii\web\Controller::redirect()|redirect()]]
去避免表单重复提交问题。

3.创建视图

最后创建两个视图文件 entry-confirm 和 entry。他们会被刚才创建的 entry 操作渲染。

entry-confirm 视图简单地显示提交的 name 和 email 数据。视图文件保存在 views/site/entry-confirm.php。

<?php
use yii\helpers\Html;
?>
<p>You have entered the following information:</p>

<ul>
<li><label>Name</label>: <?= Html::encode($model->name) ?></li>
<li><label>Email</label>: <?= Html::encode($model->email) ?></li>
</ul>


entry 视图显示一个 HTML 表单。视图文件保存在 views/site/entry.php

<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
?>
<?php $form = ActiveForm::begin(); ?>

<?= $form->field($model, 'name') ?>

<?= $form->field($model, 'email') ?>

<div class="form-group">
<?= Html::submitButton('Submit', ['class' => 'btn btn-primary']) ?>
</div>

<?php ActiveForm::end(); ?>


视图使用了一个功能强大的小部件
[[yii\widgets\ActiveForm|ActiveForm]]
去生成 HTML 表单。其中的 begin() 和 end() 分别用来渲染表单的开始和关闭标签。在这两个方法之间使用了
[[yii\widgets\ActiveForm::field()|field()]]
方法去创建输入框。第一个输入框用于 “name”,第二个输入框用于 “email”。之后使用
[[yii\helpers\Html::submitButton()]]
方法生成提交按钮。

use yii\helpers\Html;
use yii\wigets\ActiveForm;


记住使用小部件,需要引入这个两个
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: