A simple implementation of Mustache for the Dart language, which passes happily all the mustache specs. If you want to have a look at how it works, just check the tests. For more info, just read further.
In order to use the library, just add it to your pubspec.yalm
as a dependency
dependencies:
mustache4dart: '>= 1.0.0 < 2.0.0'
and then import the package
import 'package:mustache4dart/mustache4dart.dart';
and you are good to go. You can use the render toplevel function to render your template. For example:
var salutation = render('Hello {{name}}!', {'name': 'Bob'});
print(salutation); //shoud print Hello Bob!
mustache4dart will look at your given object for operators, fields or methods. For example,
if you give the template {{firstname}}
for rendering, mustache4dart will try the followings
- use the
[]
operator withfirstname
as the parameter - search for a field named
firstname
- search for a getter named
firstname
- search for a method named
firstname
- search for a method named
getFirstname
in each case the first valid value will be used.
In order to do the stuff described above the mirror library is being used which could lead to big js files when compiling the library with dartjs. The implementation does use the @MirrorsUsed
annotation but as documented this is experimental.
In order to avoid the use of the mirrors package, make sure that you compile your library with dart2js -DMIRRORS=false
. In that case though you must always make sure that your context object have a right implementation of the []
operator as it will be the only check made against them (from the ones described above) in order to define a value.
mustache4dart support partials but it needs somehow to know how to find a partial. You can do that by providing a function that returns a template given a name:
String partialProvider(String partialName) => "this is the partial with name: ${partialName}";
expect(render('[{{>p}}]', null, partial: partialProvider), '[this is the partial with name: p]'));
If you have a template that you are going to reuse with different contextes you can compile it to a function using the toplevel function compile:
var salut = compile('Hello {{name}}!');
print(salut({'name': 'Alice'})); //should print Hello Alice!
At the moment the project is under heavy development but pass all the Mustache specs. If you want to run the tests yourself, just do what drone.io does, or to put it by another way, do the following:
git clone git://github.com/valotas/mustache4dart.git
git submodule init
git submodule update
pub install
test/run.sh
If you found a bug, just create a new issue or even better fork and issue a pull request with you fix.
The library will follow a semantic versioning