1. Go to this page and download the library: Download monolyth/improse library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
monolyth / improse example snippets
class SomeController extends BaseController
{
public function actionIndex()
{
$this->data = new SomeModel;
$this->render('path/to/template.php', ['data' => $this->data]);
}
}
use Improse\View;
$view = new View('/path/to/template/file');
echo $view->render();
return emit($view->render());
echo $view->render();
echo $view;
$view->foo = 'bar';
echo $view; // The template now has $foo with value "bar"
class MyView extends Improse\View
{
// Either define the template on the class...
protected $template = '/path/to/template';
public function __construct(PDO $db)
{
// ...or pass it to the parent constructor.
parent::__construct('/path/to/template');
$stmt = $db->prepare('SELECT foo FROM bar');
$stmt->execute();
$this->foo = $stmt->fetch(PDO::FETCH_ASSOC);
}
}
$view = new View('/path/to/my/file.php');
$view->foo = 'bar';
echo $view;
<html>
<body><?=$foo
$template = new View('/path/to/main/template');
$view = new View('/path/to/some/page');
$template->page = $view;
echo $view;
class MyView extends Improse\View
{
// Define the template on the class...
protected $template = '/path/to/template';
public function __construct($template = null)
{
parent::__construct($template);
// [...snip all logic for MyView...]
}
}
$view = new MyView('/some/custom/template');
class MyView extends Improse\View
{
protected $template = '/path/to/template';
public function render()
{
// [...snip all logic for MyView...]
return parent::render();
}
}
class TwigView extends Improse\View
{
// ...[snip custom logic]...
public function render()
{
$loader = new Twig_Loader_Filesystem('/path/to/templates');
$twig = new Twig_Environment($loader, [
'cache' => '/path/to/cache/dir',
'auto_reload' => true, // or false
'debug' => true, // or false
]);
return $this->twig->render($this->template, $this->getVariables());
}
}