Тайлбар байхгүй

Justin Hileman fab64b14bf Add a `throws_exceptions` constructor option. 13 жил өмнө
bin 236ba060ca Code style updates. 14 жил өмнө
examples 6c2b85c36b Dot notation with numeric indexes fix. 13 жил өмнө
test fab64b14bf Add a `throws_exceptions` constructor option. 13 жил өмнө
.gitmodules 596fb3c1d4 Adding test support for the mustache spec. 15 жил өмнө
LICENSE 36bd2d87dc MIT License 15 жил өмнө
Mustache.php fab64b14bf Add a `throws_exceptions` constructor option. 13 жил өмнө
MustacheLoader.php 2aaa820965 Add a 'MustacheLoader' filesystem loader. 14 жил өмнө
README.markdown 53630208b6 push some whitespace around a bit. 14 жил өмнө

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