- 在官网的介绍中:EasySwoole 是一款基于Swoole Server 开发的常驻内存型的分布式PHP框架,专为API而生,摆脱传统PHP运行模式在进程唤起和文件加载上带来的性能损失。
- 那么这样就需要前后端进行分离,作为一个后端程序员,当然还是希望一站到底,这需要引入模板引擎了,我经常使用laravel进行开发,就引入blade引擎
安装渲染驱动
composer require easyswoole/template
实现驱动接口
- 引用
blade
模板引擎
composer require duncan3dc/blade=^4.5
- 新建
blade.php
文件,实现驱动接口
<?php
namespace App;
use duncan3dc\Laravel\BladeInstance;
use EasySwoole\Template\RenderInterface;
class Blade implements RenderInterface
{
private $template;
public function __construct()
{
$this->template = new BladeInstance(EASYSWOOLE_ROOT . '/App/Views', EASYSWOOLE_ROOT . '/App/Caches');
}
public function render(string $template, array $data = [], array $options = []): ?string
{
// TODO: Implement render() method.
return $this->template->render($template,$data);
}
public function afterRender(?string $result, string $template, array $data = [], array $options = [])
{
// TODO: Implement afterRender() method.
}
public function onException(\Throwable $throwable): string
{
// TODO: Implement onException() method.
return $throwable->getMessage();
}
}
事件全局注册
public static function mainServerCreate(EventRegister $register)
{
Render::getInstance()->getConfig()->setRender(new Blade());
Render::getInstance()->attachServer(ServerManager::getInstance()->getSwooleServer());
// TODO: Implement mainServerCreate() method.
}
控制器中使用
public function index()
{
$test = 56;
$this->response()->write(Render::getInstance()->render('index',compact('test')));
}
- 页面
index.blade.php
<html>
@if(false)
<div style="color:red">{{$test}}</div>
@else
<div style="color: blue">{{$test}}</div>
@endif
</html>
到这里我们已经可以在easyswoole中使用laravel框架里的模板引擎,可以使用熟悉的标签进行数据渲染