资讯专栏INFORMATION COLUMN

Yii2系列教程二:MVC Forms 和 Layouts

ThreeWords / 666人阅读

摘要:而且很明显地,我们可以看到,一旦输入框在失去焦点的时候,如果里面没有输入任何内容,每个输入框就会有相应的错误提示,用户体验很不错。

</>复制代码

  1. 原文来自: https://jellybool.com/post/programming-with-yii2-exploring-mvc-forms-a...

上一篇文章我们简单地实现了Yii2框架安装和Hello World,而在这一篇文章当中,我们会带着好奇之心去探索一下在Yii2中的几个重要的元素组成:
MVCFormsLayouts

本文的目标是创建一个小小的表单应用,就是实现一个简单的类似发微博的功能,但是我还不想牵扯到数据库那一块,因为其实数据库和表在Yii2框架之中其实还是有很多东西可以讲的,打算在下一篇的文章中会详细讲到。

MVC

模型(Model)对于我个人的简单理解就是一个概念集合,在这个集合里面包含该概念集合的多种数据,比如一个User会有姓名,性别等多个属性,这个概念集合通常就是对于数据库的一张表(如果还没有对应的数据表,则可以看作是一个集合的属性);而每一个具体的实例概念就对应一条数据记录。比如在这一篇文章之中我们会创建一个Status模型,代表状态(来源于生活:发一条状态),这个Status会有两个重要的属性,textpermissionstext就是状态本身,permissions是状态的权限。

视图(Views)通过控制器想模型请求数据,并将数据以某种特定的版式展示给用户。

控制器(Controller)可以向ModelViews发送不同的指令,一般是向Model取数据,然后读取视图文件来渲染输出数据。

在Yii2的应用中,一般是这样的:某个URL指向某个控制器的特定action,然后控制器负责向特定的模型取数据,然后将数据分配给视图渲染输出。

在这里说一下我个人的观点,我觉得其实在MVC当中,可能应该做事最多的应该是Model,与之相迎合的是,ControllerViews则相对要轻一些,Controller负责协调ModelViews,Views负责展示数据。

在Yii2的项目当中,我们将models文件放在/models/目录之下,所以我们在这个文件夹之下创建Status.php

</>复制代码

  1. ```
  2. "Private",self::PERMISSIONS_PUBLIC=>"Public");
  3. }
  4. public function getPermissionsLabel($permissions) {
  5. if ($permissions==self::PERMISSIONS_PUBLIC) {
  6. return "Public";
  7. } else {
  8. return "Private";
  9. }
  10. }
  11. }
  12. ```

这里需要注意的是rules()这个方法,它会触发Yii自带的表单验证规则,比如这里就是textpermissions这两个表单输入框都不能为空,至于getPermissions()这个方法是为了在使用dropdown输入框的时候使用的。

Status模型创建好之后,我们就可以接着创建对应的控制器和方法。在平时的开发中我习惯是为每一个模型都创建一个对应的控制器,里面一般都是包含几个最常见的方法:index, create, store, update, delete等。这里我创建一个StatusController.php,这个文件应该是位于/controllers/文件夹当中,而我们希望实现一个发表状态的功能,我们必须需要一个create操作方法,比如我们的目的是:在用户访问http://localhost:8999/status/create的时候,我们可以展示创建一条状态的页面给用户。

</>复制代码

  1. ```
  2. load(Yii::$app->request->post()) && $model->validate()) {
  3. // $model 有post数据时直接展示
  4. return $this->render("view", ["model" => $model]);
  5. } else {
  6. // 没有数据的时候,直接渲染create视图
  7. return $this->render("create", ["model" => $model]);
  8. }
  9. }
  10. }
  11. ```

首先,根据URL的规则,我们创建了一个actionCreate()方法,在这个方法里,我们通过条件判断来确定展示某个特定的视图。

创建好控制器和方法之后,我们就可以走到下一步了:创建视图。在Yii2中,视图文件的存放位置跟控制器的名字是息息相关的,比如上面我们创建了一个StatusController,我们现在首先需要在views/创建一个status/文件夹,然后在这个文件夹里创建各个跟StatusController相关的视图文件,比如上面actionCreate()return $this->render()两个视图:view.phpcreate.php

Forms

首先,我们需要一个Create视图来展示我们创建Status的表单(create.php):

</>复制代码

  1. field($model, "text")->textArea(["rows" => "4"])->label("Status Update"); ?>
  2. field($model, "permissions")->dropDownList($model->getPermissions(),
  3. ["prompt"=>"- Choose Your Permissions -"]) ?>
  4. "btn btn-primary"]) ?>

在我们平时开发web应用的时候,表单几乎总是每时每刻都得存在,只要是需要收集信息的地方就需要表单。而Yii2在对表单支持这方面做得非常不错,就如你看到的一样,上面的Yii2 ActiveForm就是Yii2内置的用来帮助我们生成表单的小组件,这里需要注意的是dropDownList这个输入框式怎么实现的,它直接使用了getPermissions(),这个方法正好返回了一个我们需要的数组。

这时候访问:http://localhost:8999/status/create 就可以看到上面创建的表单了:

至于为什么就自动排版好了,不用我们写css,那是因为Yii2默认会给我们加载Bootstrap的css文件,所以我们在使用的时候直接指定类名就OK了。而且很明显地,我们可以看到,一旦输入框在失去焦点的时候,如果里面没有输入任何内容,每个输入框就会有相应的错误提示,用户体验很不错。这个其实是得益于我们在Status模型中声明的rules()方法,Yii2会根据指定的规则通过js在前端给出相应的验证。

然后我们尝试填入一些内容,你就会看到输入框的变化了:

点击Submit 按钮,表单会提交到StatusControlleractionCreate()方法,一旦有post数据传过来,就会渲染view.php视图:


到这里,其实我们就走通整个MVC的过程,并且在这个过程中,我们顺带说了一下Forms的知识点。

Layouts

为什么要说Layouts呢?因为Layouts在Yii中其实可以看作是视图中经常重复用到的部分,比如一个HTML文件的headernavigation barfooter等,这些都是几乎是在每一个视图文件中都会用到,所以Yii采取了一种一劳永逸的方法来管理这些共用的部分:Layouts就应运而生。这样你就不用在每一个view文件中重复不必要的代码了,而且又特别好管理。

Yii允许你创建多个Layouts,不过我貌似还没遇到那样的使用场景,所以还是无法给出有实证的说法,不管怎么说,一个Layouts就基本够用了。

最后,我们借着Layouts的东风来看看我们怎么修改一下Yii2的默认导航栏:添加一个新的导航。

在上一节我就提到过viewslayoutsmain.php这个文件,里面的具体结构你可以直打开来看看,我们这里改动的是Nav::widget这部分:

</>复制代码

  1. echo Nav::widget([
  2. "options" => ["class" => "navbar-nav navbar-right"],
  3. "items" => [
  4. ["label" => "Home", "url" => ["/site/index"]],
  5. [
  6. "label" => "Status",
  7. "items" => [
  8. ["label" => "Create", "url" => ["/status/create"]],
  9. ],
  10. ],
  11. ["label" => "About", "url" => ["/site/about"]],
  12. ["label" => "Contact", "url" => ["/site/contact"]],
  13. Yii::$app->user->isGuest ?
  14. ["label" => "Login", "url" => ["/site/login"]] :
  15. ["label" => "Logout (" . Yii::$app->user->identity->username . ")",
  16. "url" => ["/site/logout"],
  17. "linkOptions" => ["data-method" => "post"]],
  18. ],
  19. ]);

我们在本来的基础之上添加了下面这个内容:

</>复制代码

  1. [
  2. "label" => "Status",
  3. "items" => [
  4. ["label" => "Create", "url" => ["/status/create"]],
  5. ],
  6. ],

这样之后,刷新一下页面,你就可以看到我们的导航变化了。而且很神奇的是:这里还实现了dropdown menu的功能,这个其实就是使用Bootstrapdropdown menu来实现的。

嗯,这篇文章貌似讲得差不多了,至少我不知道还改讲些什么了,接下来的文章我会尝试讲讲Yii2的数据库相关的内容,先睡觉。

</>复制代码

  1. 源码会放在 Github:https://github.com/JellyBool/helloYii

Happy Hacking

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/21049.html

相关文章

  • Yii2系列教程三:Database And Gii

    摘要:但是这还没有完,因为我们还需要对我们的做一些些小改动,主要是在的改动在这里,我们添加下面这两行来保障我们在插入数据的时候,和不为空。 原文来自:https://jellybool.com/post/programming-with-yii2-working-with-the-data... 上一篇文章我们理了一下Yii2的MVC,Forms和Layouts,这篇文章就直接按照...

    wemallshop 评论0 收藏0
  • Yii2系列教程四:实现用户注册,验证,登录

    摘要:开始使用邮箱配置好了之后,我们就可以开始使用了,首先我们来修改一下我们的导航栏,因为我们想实现的就是我们常常看到的在导航栏的右侧的注册和登录按钮。 原文来自: https://jellybool.com/post/programming-with-yii2-integrating-user-regi... 本来打算昨晚写的这篇教程,但是忙着约会去了,所以现在补上吧。 上一篇...

    boredream 评论0 收藏0
  • yii2搭建完美后台并实现rbac权限控制实例教程

    摘要:利用渲染后台模板后台的模板我们采用利用插播一曲是一个完全响应管理模板。基于框架,易定制模板。适合多种屏幕分辨率,从小型移动设备到大型台式机。内置了多个页面,包括仪表盘邮箱日历锁屏登录及注册错误错误等页面。 作者:白狼 出处:http://www.manks.top/yii2_fra... 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保...

    neu 评论0 收藏0
  • yii2实战教程之第一个Yii程序

    摘要:出于实战基础加之自语言的书籍出版以来,几乎所有的编程书籍都讲述了一个的例子作为开始。操作,其实就是一个是动作的意思,也可以描述为我们前面说的响应地址。 作者:白狼 出处:http://www.manks.top/document/yii_first_application.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究...

    Near_Li 评论0 收藏0
  • YII2快速学习笔记

    摘要:高性能始终是的首要目标之一。版是上代的老版本,现在处于维护状态。版是一个完全重写的版本,采用了最新的技术和协议,包括依赖包管理器代码规范命名空间特质等等。所以,我们学习版本。启用本镜像服务系统全局配置即将配置信息添加到的全局配置文件中。 工作中需要用到YII框架,于是乎,系统的学习下这套框架,详细教程请看考该站完整系列:YII2教程 一、YII简介 1、什么是YII Yii 是一个高性...

    kbyyd24 评论0 收藏0

发表评论

0条评论

ThreeWords

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<