trapvincenzo/static-view-cache

Static view cache for laravel 4

1.0 2015-03-06 09:15 UTC

This package is not auto-updated.

Last update: 2024-05-07 07:19:07 UTC


README

#Static View Cache for Laravel4 (Blade template engine)

Suppose to include a view (with dynamic data) inside another view:

<ul>
	@include('cardetail', ['car' => $car])
</ul>

For this statement, the blade engine creates a cached file for the subview like this:

<ul>
	<?php echo $__env->make('car', $car, array_except(get_defined_vars(), array('__data', '__path')))->render(); ?>;
</ul>

This means that for every request of the page, the rendering code is executed.

##Loop The problem comes when the inclusion is made inside a loop. Executing the code at every iteration, can cause a big delay in the rendering of the page.

##Cached subview What the StaticViewCache does, is to save a cached version of the generated subview with the real data. Doing so, the code for the rendering will be executed just the first time (to create the cache).

##How to use To install the StaticViewCache as a Composer package, add this line to your composer.json:

"trapvincenzo/static-view-cache": "dev-master"

and update your vendor folder running the composer update command.

Register the service provider (app/config/app.php):

'providers' => array(
	...
	'Trapvincenzo\StaticViewCache\StaticViewCacheServiceProvider'
	...
)

Replace the @include statement with:

StaticViewCache::render($viewName, $id, $data , $path )

string $viewName view name

string $id unique identifier for the view (different for each iteration)

array $data data to use inside the view

[optional] string $path define path inside storage_folder().'/views/' (default 'static')

Enjoy!