基于PhalApi的Smarty拓展

简介: 用过的童鞋都知道PhalApi是一个Api框架不提供view层的功能,但是很多童鞋有开发一个自己管理自己API的web界面的需求,或者是个人后台,那么是否意味着要去在学习另外一种框架来实现呢?**当然不是**在之前也有童鞋放出过一个View拓展,使用之后还是有一些不方便的地方,所以引入一个比较老牌的
+关注继续查看

基于PhalApi的Smarty拓展

前言

先在这里感谢phalapi框架创始人@dogstar,为我们提供了这样一个优秀的开源框架.

用过的童鞋都知道PhalApi是一个Api框架不提供view层的功能,但是很多童鞋有开发一个自己管理自己API的web界面的需求,或者是个人后台,那么是否意味着要去在学习另外一种框架来实现呢?当然不是在之前也有童鞋放出过一个View拓展,使用之后还是有一些不方便的地方,所以引入一个比较老牌的PHP模版引擎Smarty来解决这类问题,本拓展提供了对Smarty的封装,而且Smarty内容比较多在此处不会依依交与大家使用,希望的童鞋可以自己探索关于Smarty的功能,有不便之处需要封装与之联系!

注:本拓展并没有开发完成,也没进行严格的测试,此版本为还处于开发阶段的鉴赏版.

附上:

官网地址:http://www.phalapi.net/

开源中国Git地址:http://git.oschina.net/dogstar/PhalApi/tree/release

PhalApi Library:http://git.oschina.net/dogstar/PhalApi-Library

初始化Smarty

PhalApi-Smarty的初始化也和其他拓展一样,我们只需要把上方PhalApi Library中的Smarty文件目录放到需要用到的项目的拓展中即可.

但是view拓展和其他拓展有一些本质的区别就是需要有存放view页面的地方,这里使用一个干净的PhalApi项目进行演示,我们在public下创建如下结构

然后我们在init末尾中加入如下代码:


//接受一个参数,参数为view的路径
DI()->smarty = new Smarty_Lite('view');

现在我们就已经初始化好了PhalApi-Smarty

一个简单的例子

我们在Default.Index接口中做如下修改:

public function index() {

    $param = array(
        'name' => '喵咪',
        'list' => array(
            array(
                "id"   => 1,
                "name" => "test"
            ),
            array(
                "id"   => 2,
                "name" => "test2"
            )
        )
    );
    DI()->smarty->setParams($param);
    DI()->smarty->show();
}

同时修改index.tpl:

<HTML>
<HEAD>
    <style type="text/css">
        p,table{
            margin: auto;
            width: 60%;
        }
    </style>
</HEAD>
<BODY>
Hello {$name}, welcome to smarty<br/>

<table border="1">
    {section name = sec loop = $list}
        <tr>
            <td>{$list[sec].id}</td>
            <td>{$list[sec].name}</td>
        </tr>
    {/section}
</table>

</BODY>
</HTML>

此时我们再次运行Default.Index接口就有如下显示:

setParams函数作为参数的媒介把接口中获取的参数放到模版里面进行处理,接受一个数组具体实现是对每一个参数进行assign操作,具体可以参考Smarty

我们在show默认不传递参数是,会更具模块名和接口名来匹配对于的模版,比如Default.Index就会匹配到view/Default/Index.tpl,当然我们也可以指定跳转到摸个模版,比如创建一个模版名称为test.tpl,然后创建一个Default.test接口,我们在index接口进行一些修改


DI()->smarty->show("Default.test");

这个时候我们访问Default.Index接口的时候就会先执行Default.Index的代码然后在执行,test方法的代码最好渲染Default中的test.tpl模版

注意:show跳转其他模块接口会执行跳转的接口,如果有参数验证会被拦截,所以使用场景比较适合处理用户登录过时跳转登录页面重新登录这类业务

其他

如果大家在使用IDE开发的时候嫌DI->smarty没有提示的话可以在如下目录加入此注释

\PhalApi\PhalApi\DI.php

这样就可以看到如下效果

总结

当前只是提供了一个简单的封装还有很多需要优化封装的功能其他各位小伙伴的补充.

相关文章
|
2月前
|
监控 安全 BI
一套医疗安全不良事件管理系统源码(PHP+ vue2+element+ laravel)
不良事件报告管理系统按照不良事件的管理部门不同,分为医疗不良事件、护理不良事件、药品不良反应事件、院内感染事件、输血不良反应事件、医疗器械不良事件、医技相关不良事件、安保后勤不良事件、信息不良事件、费用窗口服务不良事件共10大类事件。
一套医疗安全不良事件管理系统源码(PHP+ vue2+element+ laravel)
|
5月前
|
PHP 索引
最为常用的Laravel操作(3)-模板
整理了 Laravel 框架模板最常用的操作,如模板常用语法、模板继承、流程控制、循环等。本系列共有 3 篇文章。
36 0
|
容器
Phalcon如何创建多模块并能进行访问 《Phalcon入坑指南系列 四》(2)
Phalcon如何创建多模块并能进行访问 《Phalcon入坑指南系列 四》
118 0
Phalcon如何创建多模块并能进行访问 《Phalcon入坑指南系列 四》(2)
|
应用服务中间件 nginx
Phalcon如何创建多模块并能进行访问 《Phalcon入坑指南系列 四》(1)
Phalcon如何创建多模块并能进行访问 《Phalcon入坑指南系列 四》
140 0
Phalcon如何创建多模块并能进行访问 《Phalcon入坑指南系列 四》(1)
|
XML 前端开发 JavaScript
Markdown 拓展-Docsify 构建接口文档
优点:使用 markdown 编写,docsify 作为支撑。快速高效,若搭载搜索功能,功能较为完善。且可部署在内网环境。 缺点:不支持直接点击按钮进行 HTTP 请求,需要手动粘贴参数到 POSTMAN 等工具。 Docsify 初始化 & 运行
97 0
Markdown 拓展-Docsify 构建接口文档
|
PHP 开发工具 git
Yii2语言国际化配置Twig翻译解决方案
转载 Yii2语言国际化配置Twig翻译解决方案 我自己在写项目的时候,不喜欢使用php自身的模板,主要是各种PHP标签让我烦,而且对Html的标签兼容也不够友好,所以我后面采用了twig模板,配置之类的也是很方便,写...
1196 0
|
PHP 安全
Codeigniter 3 拓展HMVC
Codeigniter 3 对于Codeigniter 2.X系列版本进行了一次大的变革,所以很多在2.X版本的代码到3.x版本已经不适用了。本文部分代码依旧是使用CI2由Jens Segers开源的代码,向开源前辈致敬!
1618 0