phalcon-入门篇9(view层基础使用)
#phalcon-入门篇9(view层基础使用)#
本教程基于phalcon2.0.9版本
##前言## 先在这里感谢各位phalcon技术爱好者,我们提供这样一个优秀的交流平台
哈喽大家好呀,期待已久的第9篇终于和大家见面了,时隔半个多月在之间小编对编写phalcon的语言zephir进行了文档译文讲解以及在忙这工作上的一系列事情所以在这里给大家道个歉迟来了这么久,那么今天的主要类容是简单的介绍一下基本的view层在phalcon中要如何的运用,话不多说让我们开始今天的旅程把!
注:笔者水平有限,说的不正确的地方希望大家多多指正,一同交流技术
附上:
喵了个咪的博客:http://w-blog.cn
教程代码库:http://git.oschina.net/wenzhenxi/Phalcon-tutorial
phalcon官网地址:https://phalconphp.com
phalcon中文社区:http://www.iphalcon.cn/
##1. 分层渲染##
分层渲染顾名思义,就是在把不同层模版结合在一起渲染成一个整体的模版,一个很恰当的例子就是一个公司官网他的标题都是通用的,他的上面的菜单栏也是通用的,但是当在写莫一个模块中的莫一个页面的时候这些公用的地方还需要重写吗,这个答案当然是不,phalcon也很巧妙的考虑到了这一点,我们来看看它的分层渲染机制是怎样的
###1.1 分层渲染###
按照往常的规范我们建议一个名为ViewController的控制器然后填充代码如下:
<?php
use PhalconMvcController;
class ViewController extends Controller {
public function indexAction($Id) {
$this->view->Id = $Id;
}
}
接着我们准备我们的view层的结构:
大家可以看到我们view对应的应该是view/index.phtml,那么layouts和根目录的index.phtml是干嘛的呢?先别着急我们先给这三个文件填充一下类容:
view/index.phtml:
<h3>这个是view控制器的index模版!</h3>
<p>这里有个参数是 <?php echo $Id; ?></p>
layouts/View.phtml**(注意如果要对view模块生效必须同名)**:
<h2>这个是view控制器的布局文件!</h2>
<?php echo $this->getContent(); ?>
index.phtml:
<html>
<head>
<title>Example</title>
</head>
<body>
<h1>这个是默认的布局文件!</h1>
<?php echo $this->getContent(); ?>
</body>
</html>
然后接着我们来运行一下看看结果如何:
http://phalcon.w-blog.cn/phalcon/View/index/5
从这个地方可以看出渲染程序先进入了index.phtml在index.phtml的代码中引入了layouts/View.phtml中的代码,然后在layouts/View.phtml中映入了我们控制器中输出了参数的代码,这样就是一个完整的分层渲染的逻辑了,大家可以好好体会一下!
###1.2 使用模版###
那么有人问了我要是在view模块中也同样复用其他模块的layouts咋办呢,那么在这里就有一控制渲染的已经小技巧了
我们在控制器中加入如下代码:
public function initialize()
{
$this->view->setTemplateAfter('common');
}
然后在layouts文件夹下面创建common.phtml加入如下代码:
<h2>这个是common控制器的布局文件!</h2>
<?php echo $this->getContent(); ?>
然后我们在运行
http://phalcon.w-blog.cn/phalcon/View/index/5
我们会发现不仅仅调用了layouts中的view.phtml而且也使用了common.phtml
$this->view->setTemplateBefore('common')和$this->view->setTemplateAfter('common')可以控制渲染顺序
##2. 选择视图##
当我们在做很多项目的时候往往很多页面是复用的,虽然我们制定了很多不同的Action但是要怎么通用一个模版呢,phalcon咋这里提供了一个模版选择的功能,你可以选择渲染制定的一个模版
方法如下:
public function indexAction($Id) {
$this->view->pick("Index/index");
$this->view->Id = $Id;
}
这个时候制定了pick之后我们在此请求的内容就变成如下结果了:
##3. 小结##
应为小编并不是特别擅长view层的使用,所以还有部分小编觉得不是太重要的类容并没有涉及到,有兴趣的同学可以参考官方文档,那么今天的教程就到这里的多谢大家的关注!
注:笔者能力有限有说的不对的地方希望大家能够指出,也希望多多交流!
Phalcon技术交流:364520707 PhalCon中文社区:287484785 欢迎大家的加入!
- Windows主机管理系统Websitepanel
- 自定义Appfabric Cache 配置提供程序
- 2017年发生在上海的科技大新闻
- REST当中为什么要使用HTTP PUT
- 推荐一个在Linux/Unix上架设ASP.NET的 WEB服务器--Jexus
- 人工智能与工业融合:没有你,对我很重要……
- DeepMind哈萨比斯对话哈里王子:2018年AI最大的突破在生物或化学
- 提升用户体验,微信小程序“授权失败”场景的优雅处理
- extjs 基础部分
- WordPress 网站开发“微信小程序”实战(二)
- Extjs form 组件
- Extjs grid 组件
- WordPress 网站开发“微信小程序”实战(三)
- Extjs mvc
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- leetcode每日一题-99. 恢复二叉搜索树
- Java 两个经纬度获取方位
- 使用Python实现基本初等函数可视化
- 递归回溯--复原IP地址
- 通过 generic-webhook-trigger 插件实时获取 Bitbucket Repository Events
- 初识TypeScript:查找指定路径下的文件按类型生成json
- Xamarin Forms WPF 干掉默认的窗口导航条
- WPF 从零手动创建承载 Xamarin Forms 项目
- 帝都房价回调?带你用Python了解北京二手房市场现状
- Zabbix 利用 ncat 监控远端端口状态
- MySQL“被动”性能优化汇总!
- H3C WA2610i-GN 无线AP FAT 配置案例
- java强引用、软引用、弱引用、虚引用以及FinalReference
- 读源码——JDK动态代理
- 图解红黑树