No Description

Justin Hileman 0178e3e531 Merge branch 'release/1.0.0' 13 years ago
bin 236ba060ca Code style updates. 14 years ago
examples 6c2b85c36b Dot notation with numeric indexes fix. 13 years ago
test fab64b14bf Add a `throws_exceptions` constructor option. 13 years ago
.gitmodules 596fb3c1d4 Adding test support for the mustache spec. 15 years ago
LICENSE 36bd2d87dc MIT License 15 years ago
Mustache.php b30d938441 Bump version number. 13 years ago
MustacheLoader.php 2aaa820965 Add a 'MustacheLoader' filesystem loader. 14 years ago
README.markdown 53630208b6 push some whitespace around a bit. 14 years ago

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