Hello World

  • 创建动作
  • 创建视图
  • 运行
  • 总结

本章描述了如何在你的应用中创建一个新的 “Hello” 页面。为了实现这一目标,将会创建一个操作 和一个视图

  • 应用将会分发页面请求给动作
  • 动作将会依次渲染视图呈现 “Hello” 给最终用户

整个章节,你将会掌握三件事:

  1. 如何创建一个动作去响应请求,
  2. 如何创建一个视图去构造响应内容,
  3. 以及一个应用如何分发请求给动作

创建动作

为了 “Hello”,需要创建一个 index 操作,从请求中接收 message 参数并显示给最终用户。如果请求没有提供 message 参数,操作将显示默认参数 “hello”。你可以直接在 DefaultController 控制器里声明 index 操作。

这个控制器是由文件 controllers/DefaultController.php 定义的。以下是一个操作的声明:

<?php

namespace app\controllers;

class DefaultController extends \wii\web\Controller
{
    public function actionIndex()
    {
        $this->renderData['message'] = $this->request->get('message', 'hello');
        return $this->render('index');
    }
}

在上述 DefaultController 代码中,index 操作被定义为 actionIndex 方法。
Wii 使用 action 前缀区分普通方法和操作。action 前缀后面的名称被映射为操作的 ID。操作 ID 总是被以小写处理,如果一个操作 ID 由多个单词组成,单词之间将由连字符连接(如 create-comment)。操作 ID 映射为方法名时移除了连字符,将每个单词首字母大写,并加上 action 前缀。例子:操作 ID create-comment 相当于方法名 actionCreateComment

当应用接收到请求并确定由 index 操作来响应请求时,action可以获取请求的参数值。如果请求包含一个 message 参数,它的值是 “Goodybye”, 操作方法中的 $message 变量也将被填充为 “Goodbye”。在操作方法中,[[wii\web\Controller::render()|render()]] 被用来渲染一个名为 index视图文件。message 参数也被传入视图,这样就可以在里面使用。操作方法会返回渲染结果。结果会被应用接收并显示给最终用户的浏览器(作为整页 HTML 的一部分)。

创建视图

视图是你用来生成响应内容的脚本。为了说 “Hello”,你需要创建一个 index 视图,以便显示从操作方法中传来的 message 参数。

<?php
use wii\helpers\Html;
?>
<?php echo \wii\helpers\Html::encode($message);?>

index 视图应该存为 views/site/index.php 文件。当一个操作中调用了 [[wii\web\Controller::render()|render()]] 方法时,
它将会按 views/控制器 ID/视图名.php 路径加载 PHP 文件。

注意以上代码,message 参数在输出之前被[[wii\helpers\Html::encode()|HTML-encoded]] 方法处理过。这很有必要,当参数来自于最终用户时,参数中可能隐含的恶意 JavaScript 代码会导致跨站脚本(XSS)攻击

当然了,你大概会在 index 视图里放入更多内容。内容可以由 HTML 标签,纯文本,甚至 PHP 语句组成。实际上 index 视图就是一个由 [[wii\web\Controller::render()|render()]] 执行的 PHP 脚本。视图脚本输出的内容将会作为响应结果返回给应用。应用将依次输出结果给最终用户。

运行

创建完动作和视图后,你就可以通过下面的 URL 访问新页面了:

http://hostname/default/index?message=Hello World

Hello World

这个 URL 将会输出包含 “Hello World” 的页面。

如果你省略 URL 中的 message 参数,将会看到页面只显示 “Hello”。这是因为 message 被作为一个参数传给 actionIndex() 方法,当省略它时,参数将使用默认的 “Hello” 代替。

信息:新页面和其它页面使用同样的头部和尾部是因为 [[wii\web\Controller::render()|render()]]方法会自动把 index 视图执行的结果嵌入称为布局的文件中,本例中是 views/layouts/main.php

指向特定操作的独立 ID。路由格式是 控制器 ID/操作 ID。应用接受请求的时候会检查参数,使用控制器 ID 去确定哪个控制器应该被用来处理请求。然后相应控制器将使用操作 ID 去确定哪个操作方法将被用来做具体工作。上述例子中,路由 default/index 将被解析至 DefaultController 控制器和其中的 index 操作。因此 DefaultController::actionIndex() 方法将被调用处理请求。

Info: 与操作一样,一个应用中控制器同样有唯一的 ID。控制器 ID 和操作 ID 使用同样的命名规则。控制器的类名源自于控制器 ID,移除了连字符,每个单词首字母大写,并加上 Controller 后缀。例子:控制器 ID post-comment 相当于控制器类名PostCommentController

总结

通过本章节你接触了 MVC 设计模式中的控制器和视图部分。创建了一个操作作为控制器的一部分去处理特定请求。然后又创建了一个视图去构造响应内容。在这个小例子中,没有模型调用,唯一涉及到数据的地方是 message 参数。

你同样学习了 Wii 路由的相关内容,它是用户请求与控制器动作之间的桥梁。

results matching ""

    No results matching ""