Bez popisu

Justin Hileman 19289f85e4 Rename MustacheCallTest Foo class so it can be run with other tests před 13 roky
bin 236ba060ca Code style updates. před 14 roky
examples 81d764580c Fix undefined `self` in the i18n example. před 14 roky
test 19289f85e4 Rename MustacheCallTest Foo class so it can be run with other tests před 13 roky
.gitmodules 596fb3c1d4 Adding test support for the mustache spec. před 15 roky
LICENSE 36bd2d87dc MIT License před 15 roky
Mustache.php 0a76694169 Remove deprecated call in _renderTemplate call. před 14 roky
MustacheLoader.php 2aaa820965 Add a 'MustacheLoader' filesystem loader. před 14 roky
README.markdown 53630208b6 push some whitespace around a bit. před 14 roky

README.markdown

Mustache.php

A Mustache implementation in PHP.

Usage

A quick example:

<?php
include('Mustache.php');
$m = new Mustache;
echo $m->render('Hello {{planet}}', array('planet' => 'World!'));
// "Hello World!"

And a more in-depth example--this is the canonical Mustache template:

Hello {{name}}
You have just won ${{value}}!
{{#in_ca}}
Well, ${{taxed_value}}, after taxes.
{{/in_ca}}

Along with the associated Mustache class:

<?php
class Chris extends Mustache {
    public $name = "Chris";
    public $value = 10000;
    
    public function taxed_value() {
        return $this->value - ($this->value * 0.4);
    }

    public $in_ca = true;
}

Render it like so:

<?php
$chris = new Chris;
echo $chris->render($template);

Here's the same thing, a different way:

Create a view object--which could also be an associative array, but those don't do functions quite as well:

<?php
class Chris {
    public $name = "Chris";
    public $value = 10000;

    public function taxed_value() {
        return $this->value - ($this->value * 0.4);
    }

    public $in_ca = true;
}

And render it:

<?php
$chris = new Chris;
$m = new Mustache;
echo $m->render($template, $chris);

Known Issues

  • As of Mustache spec v1.1.2, there are a couple of whitespace bugs around section tags... Despite these failing tests, this version is actually closer to correct than previous releases.

See Also