前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Yii 框架使用Forms操作详解

Yii 框架使用Forms操作详解

作者头像
砸漏
发布2020-11-02 10:44:22
3.1K0
发布2020-11-02 10:44:22
举报
文章被收录于专栏:恩蓝脚本

本文实例讲述了Yii 框架使用Forms操作。分享给大家供大家参考,具体如下:

创建模型

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

代码语言:javascript
复制
<?php
 
namespace 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, 该基类通常用来表示数据。

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

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

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

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

创建动作

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

代码语言:javascript
复制
<?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 表单), 操作将调用 validate() 去确保用户提交的是有效数据。

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

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

创建视图

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

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

代码语言:javascript
复制
<?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

代码语言:javascript
复制
<?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(); ? 

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

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

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

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

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

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

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

代码语言:javascript
复制
<?= $form- field($model, 'name')- label('自定义 Name') ? 
<?= $form- field($model, 'email')- label('自定义 Email') ? 

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

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 创建模型
  • 创建动作
  • 创建视图
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档