使用表单

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

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

    • 创建一个代表用户通过表单输入的数据
    • 声明规则去验证输入的数据
    • 视图中生成一个 HTML 表单

    模型类 代表从用户那请求的数据,
    该类如下所示并存储在 models/EntryForm.php 文件中。
    请参考章节获取更多关于类命名约定的介绍。

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

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

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

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

    1. <?php
    2. $model = new EntryForm();
    3. $model->name = 'Qiang';
    4. $model->email = 'bad';
    5. if ($model->validate()) {
    6. // 验证成功!
    7. } else {
    8. // 失败!
    9. }

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

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

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

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

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

    1. <?php
    2. use yii\helpers\Html;
    3. ?>
    4. <p>You have entered the following information:</p>
    5. <ul>
    6. <li><label>Name</label>: <?= Html::encode($model->name) ?></li>
    7. <li><label>Email</label>: <?= Html::encode($model->email) ?></li>

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

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

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

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

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

    输入数据的确认页

    你可能会好奇 HTML 表单暗地里是如何工作的呢,
    看起来它可以为每个输入框显示文字标签,
    而当你没输入正确的信息时又不需要刷新页面就能给出错误提示,似乎有些神奇。

    是的,其实数据首先由客户端 JavaScript 脚本验证,然后才会提交给服务器通过 PHP 验证。
    [[yii\widgets\ActiveForm]] 足够智能到把你在 EntryForm
    模型中声明的验证规则转化成客户端 JavaScript 脚本去执行验证。
    如果用户浏览器禁用了 JavaScript,
    服务器端仍然会像 actionEntry() 方法里这样验证一遍数据。这保证了任何情况下用户提交的数据都是有效的。

    输入框的文字标签是 field() 方法生成的,内容就是模型中该数据的属性名。
    例如模型中的 属性生成的标签就是 Name

    你可以在视图中自定义标签
    按如下方法:

    本章节指南中你接触了 MVC 设计模式的每个部分。
    学到了如何创建一个模型代表用户数据并验证它的有效性。

    你还学到了如何从用户那获取数据并在浏览器上回显给用户。
    这本来是开发应用的过程中比较耗时的任务,
    好在 Yii 提供了强大的小部件让它变得如此简单。