`
dcj3sjt126com
  • 浏览: 1868237 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

[入门]使用Forms

    博客分类:
  • Yii2
阅读更多

使用表单

本章节介绍如何创建一个让用户提交数据的表单页。该页将显示一个包含 name 输入框和 email 输入框的表单。当提交这两部分信息后,页面将会显示用户所输入的信息。

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

贯穿整个小节,你将会学到:

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

创建模型 

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

<?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() 获取错误详情
}

创建操作 

下面你得在 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 代表应用实例,它是一个全局可访问的单例。同时它也是一个服务定位器,能提供 requestresponsedb 等等特定功能的组件。在上面的代码里就是使用 request 组件来访问应用实例收到的 $_POST 数据。

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

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

创建视图 

最后创建两个视图文件 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()]] 方法生成提交按钮。

尝试下 

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

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

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

验证错误的表单

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

输入数据的确认页

效果说明 

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

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

警告:客户端验证是提高用户体验的手段。无论它是否正常启用,服务端验证则都是必须的,请不要忽略它。

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

你可以在视图中自定义标签:

<?= $form->field($model, 'name')->label('自定义 Name') ?>
<?= $form->field($model, 'email')->label('自定义 Email') ?>

补充:Yii 提供了相当多类似的小部件去帮你生成复杂且动态的视图。在后面你还会了解到自己写小部件是多么简单。你可能会把自己的很多视图代码转化成小部件以提高重用,加快开发效率。

总结 

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

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

下一章你将学习如何使用数据库,几乎每个应用都需要数据库。

分享到:
评论

相关推荐

    ORACLE forms开发整理

    在使用Oracle Forms进行开发时,开发者可以利用其内置的触发器和函数,创建复杂的业务逻辑。此外,Forms提供了丰富的图形组件,如按钮、文本字段、列表框等,用于构建用户界面。通过Forms Builder,开发者可以直观...

    Xamarin Forms入门

    ### Xamarin Forms 入门知识点概览 #### 一、Xamarin.Forms 概述 - **Xamarin.Forms** 是一个跨平台的应用开发框架,允许开发者使用单一的共享代码库来构建原生用户界面(UI)和业务逻辑(BL),支持 iOS、Android...

    C Sharp Windows Forms 程序设计.pdf

    本书《C Sharp Windows Forms 程序设计》详细介绍了如何使用C#在.NET Framework下进行Windows Forms的应用程序开发。Windows Forms是一种面向对象的类库,提供了丰富的控件,如按钮、标签、列表框等,以及创建窗口...

    Windows应用程序开发入门到精通二:在VS.NET中使用Windows Forms创建最好的用户体验

    【Windows应用程序开发入门到精通二:在VS.NET中使用Windows Forms创建最好的用户体验】 Windows应用程序开发是计算机编程领域的重要部分,特别是在企业级应用和桌面软件设计中。本教程将引导你从初学者到精通,...

    Windows Forms Programming With C#.pdf

    根据提供的文件信息,我们可以从《使用C#进行Windows表单编程》这本书中提炼出一系列重要的知识点,涵盖了从入门到高级的各个层面。下面将详细展开这些知识点。 ### 一、入门指南 #### 1.1 开始使用Windows Forms ...

    Xamarin Forms中文文档

    - **定义与特点**:Xamarin.Forms 是一个跨平台的 UI 框架,允许开发者使用 C# 和 XAML 构建原生 UI 的移动应用。它支持 iOS、Android、Windows 等多个平台,提供了一种高效的方式来构建共享 UI 层。 - **核心概念**...

    Xamarin.Forms教程

    Xamarin.Forms教程涵盖了一系列开发技术,包括使用C#语言和XAML标记语言构建跨平台移动应用的方法。Xamarin.Forms是微软开发的一个开源UI工具包,它允许开发者用XAML和C#编写代码来创建和部署原生用户界面布局,这些...

    windows forms programming with c# - manning.pdf

    综上所述,《Windows Forms编程与C#》是一本全面介绍如何使用C#语言开发Windows Forms应用程序的书籍,不仅适合初学者入门学习,也适合有经验的开发者深入了解更高级的主题。通过对本书的学习,开发者可以掌握创建高...

    c#入门经典(第四版)第16章 windows forms高级功能

    在《C#入门经典》(第四版)的第16章中,作者深入探讨了Windows Forms的高级功能,这是微软.NET框架中用于构建桌面应用程序的关键技术。本章节旨在帮助读者掌握更复杂、更灵活的界面设计与编程技巧,从而创建出用户...

    在实战中成长Windows Forms开发之路.pdf

    《在实战中成长:Windows Forms开发之路》是一本通俗易懂的C#入门指导图书。《在实战中成长:Windows Forms开发之路》以一个真实的软件项目——RSS阅读器为主线,全面阐释了使用C#进行Windows Forms应用软件开发的概念...

    在实战中成长windows forms开发之路

    4. **Windows Forms入门**: Windows Forms是用于创建桌面应用程序的UI框架,书中会介绍如何创建窗口、添加控件(如按钮、文本框、标签等)、布局管理、控件事件处理,以及窗体的基本操作如大小调整、位置移动等。 ...

    windowforms初学者案例 C#编程 入门 人事档案管理系统

    【标题】"WindowForms初学者案例 C#编程 入门 人事档案管理系统" 在这个项目中,我们关注的是基于C#的WindowForms应用开发,特别针对初学者设计的一个入门级实例——人事档案管理系统。WindowForms是.NET Framework...

    PrismHandsOn:Xamarin的Prism.Forms入门动手

    Xamarin的Prism.Forms入门动手対象者本ハンズオンは次のような方を想定しています。 Xamarin.Formsの基本を理解しているXamarin的棱镜。表格をこれから学习しようとしているはじめにスライド环境について追加ースス...

    windows forms编程进阶

    入门基础,通过对此文档的学习,相信你会掌握windows forms的基本应用。

    Spread for Windows Forms 5.0 中文帮助chm,开发者指南

    1. **快速入门**:引导开发者快速了解Spread控件的基本用法,包括添加控件、设置基本属性等。 2. **API参考**:详细列出所有类、方法、属性和事件,便于查阅和使用。 3. **示例代码**:提供各种示例代码,展示如何...

    Windows应用程序开发入门到精通九:安全的配置并部署.NET Windows Forms应用程序

    在本课程“Windows应用程序开发入门到精通九:安全的配置并部署.NET Windows Forms应用程序”中,我们将深入探讨如何创建、配置以及安全地部署基于.NET Framework的Windows Forms应用。这一环节对于任何开发者来说都...

    Visual C 2008入门经典 带目录

    《Visual C++2008入门经典》延续了Ivor Horton讲解编程语言的独特方法,从中读者可以学习Visual C++ 2008的基础知识,了解如何使用MFC进行本地ISO/ANSI C++ Windows应用程序开发以及如何使用Windows Forms进行C++/...

    Visual_C++2008入门经典(中文版)

    《Visual C++2008入门经典》延续了Ivor Horton讲解编程语言的独特方法,从中读者可以学习Visual C++ 2008的基础知识,了解如何使用MFC进行本地ISO/ANSI C++ Windows应用程序开发以及如何使用Windows Forms进行C++/...

    正宗《Visual C++2008入门经典》中文版part1 pdf

    本书延续了Ivor Horton讲解编程语言的独特方法,从中读者可以学习Visual C++ 2008的基础知识,了解如何使用MFC进行本地ISO/ANSI C++ Windows应用程序开发以及如何使用Windows Forms进行C++/CLI Windows应用程序开发...

Global site tag (gtag.js) - Google Analytics