您的位置 首页 技术

yii框架如何使用表单

如何创建一个让用户提交数据的表单页。 该页将显示一个包含 name 输入框和 email 输入框的表单。 当提交这两部分信息后,页面将会显示用户所输入的信息。 (推荐学习:yii框…

如何创建一个让用户提交数据的表单页。 该页将显示一个包含 name 输入框和 email 输入框的表单。 当提交这两部分信息后,页面将会显示用户所输入的信息。 (推荐学习:yii框架)

为了实现这个目标,除了创建一个操作和两个视图外, 还需要创建一个模型。

通过本教程,你将会学到:

创建一个模型代表用户通过表单输入的数据

声明规则去验证输入的数据

在视图中生成一个 HTML 表单

创建模型

模型类 EntryForm 代表从用户那请求的数据, 该类如下所示并存储在 models/EntryForm.php 文件中。

<?phpnamespace app\models;use Yii;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 对象, 你可以调用它的 validate() 方法触发数据验证。 如果有数据验证失败,将把 hasErrors 属性设为 ture, 想要知道具体发生什么错误就调用 getErrors。

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

创建动作

下面你得在 site 控制器中创建一个 entry 操作用于新建的模型。

<?phpnamespace 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 表单), 操作将调用 validate() 去确保用户提交的是有效数据。

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

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

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

创建视图 ?

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

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

<?phpuse 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。

<?phpuse 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(); ?>

用浏览器访问下面的 URL 看它能否工作:

http://hostname/index.php?r=site/entry

你会看到一个包含两个输入框的表单的页面。每个输入框的前面都有一个标签指明应该输入的数据类型。 如果什么都不填就点击提交按钮,或填入格式不正确的 email 地址,将会看到在对应的输入框下显示错误信息。

yii-5.png输入有效的 name 和 email 信息并提交后, 将会看到一个显示你所提交数据的确认页面。

yii-6.png

以上就是yii框架如何使用表单的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/12668.html

为您推荐

返回顶部