Simple email application for Android. Original source code: https://framagit.org/dystopia-project/simple-email
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

168 lines
8.7 KiB

  1. [![Travis Build Status](https://img.shields.io/travis/wycats/handlebars.js/master.svg)](https://travis-ci.org/wycats/handlebars.js)
  2. [![Appveyor Build Status](https://ci.appveyor.com/api/projects/status/github/wycats/handlebars.js?branch=master&svg=true)](https://ci.appveyor.com/project/wycats/handlebars-js)
  3. [![Selenium Test Status](https://saucelabs.com/buildstatus/handlebars)](https://saucelabs.com/u/handlebars)
  4. Handlebars.js
  5. =============
  6. Handlebars.js is an extension to the [Mustache templating
  7. language](http://mustache.github.com/) created by Chris Wanstrath.
  8. Handlebars.js and Mustache are both logicless templating languages that
  9. keep the view and the code separated like we all know they should be.
  10. Checkout the official Handlebars docs site at
  11. [http://www.handlebarsjs.com](http://www.handlebarsjs.com) and the live demo at [http://tryhandlebarsjs.com/](http://tryhandlebarsjs.com/).
  12. Installing
  13. ----------
  14. See our [installation documentation](http://handlebarsjs.com/installation.html).
  15. Usage
  16. -----
  17. In general, the syntax of Handlebars.js templates is a superset
  18. of Mustache templates. For basic syntax, check out the [Mustache
  19. manpage](http://mustache.github.com/mustache.5.html).
  20. Once you have a template, use the `Handlebars.compile` method to compile
  21. the template into a function. The generated function takes a context
  22. argument, which will be used to render the template.
  23. ```js
  24. var source = "<p>Hello, my name is {{name}}. I am from {{hometown}}. I have " +
  25. "{{kids.length}} kids:</p>" +
  26. "<ul>{{#kids}}<li>{{name}} is {{age}}</li>{{/kids}}</ul>";
  27. var template = Handlebars.compile(source);
  28. var data = { "name": "Alan", "hometown": "Somewhere, TX",
  29. "kids": [{"name": "Jimmy", "age": "12"}, {"name": "Sally", "age": "4"}]};
  30. var result = template(data);
  31. // Would render:
  32. // <p>Hello, my name is Alan. I am from Somewhere, TX. I have 2 kids:</p>
  33. // <ul>
  34. // <li>Jimmy is 12</li>
  35. // <li>Sally is 4</li>
  36. // </ul>
  37. ```
  38. Full documentation and more examples are at [handlebarsjs.com](http://handlebarsjs.com/).
  39. Precompiling Templates
  40. ----------------------
  41. Handlebars allows templates to be precompiled and included as javascript code rather than the handlebars template allowing for faster startup time. Full details are located [here](http://handlebarsjs.com/precompilation.html).
  42. Differences Between Handlebars.js and Mustache
  43. ----------------------------------------------
  44. Handlebars.js adds a couple of additional features to make writing
  45. templates easier and also changes a tiny detail of how partials work.
  46. - [Nested Paths](http://handlebarsjs.com/#paths)
  47. - [Helpers](http://handlebarsjs.com/#helpers)
  48. - [Block Expressions](http://handlebarsjs.com/#block-expressions)
  49. - [Literal Values](http://handlebarsjs.com/#literals)
  50. - [Delimited Comments](http://handlebarsjs.com/#comments)
  51. Block expressions have the same syntax as mustache sections but should not be confused with one another. Sections are akin to an implicit `each` or `with` statement depending on the input data and helpers are explicit pieces of code that are free to implement whatever behavior they like. The [mustache spec](http://mustache.github.io/mustache.5.html) defines the exact behavior of sections. In the case of name conflicts, helpers are given priority.
  52. ### Compatibility
  53. There are a few Mustache behaviors that Handlebars does not implement.
  54. - Handlebars deviates from Mustache slightly in that it does not perform recursive lookup by default. The compile time `compat` flag must be set to enable this functionality. Users should note that there is a performance cost for enabling this flag. The exact cost varies by template, but it's recommended that performance sensitive operations should avoid this mode and instead opt for explicit path references.
  55. - The optional Mustache-style lambdas are not supported. Instead Handlebars provides its own lambda resolution that follows the behaviors of helpers.
  56. - Alternative delimiters are not supported.
  57. Supported Environments
  58. ----------------------
  59. Handlebars has been designed to work in any ECMAScript 3 environment. This includes
  60. - Node.js
  61. - Chrome
  62. - Firefox
  63. - Safari 5+
  64. - Opera 11+
  65. - IE 6+
  66. Older versions and other runtimes are likely to work but have not been formally
  67. tested. The compiler requires `JSON.stringify` to be implemented natively or via a polyfill. If using the precompiler this is not necessary.
  68. [![Selenium Test Status](https://saucelabs.com/browser-matrix/handlebars.svg)](https://saucelabs.com/u/handlebars)
  69. Performance
  70. -----------
  71. In a rough performance test, precompiled Handlebars.js templates (in
  72. the original version of Handlebars.js) rendered in about half the
  73. time of Mustache templates. It would be a shame if it were any other
  74. way, since they were precompiled, but the difference in architecture
  75. does have some big performance advantages. Justin Marney, a.k.a.
  76. [gotascii](http://github.com/gotascii), confirmed that with an
  77. [independent test](http://sorescode.com/2010/09/12/benchmarks.html). The
  78. rewritten Handlebars (current version) is faster than the old version,
  79. with many [performance tests](https://travis-ci.org/wycats/handlebars.js/builds/33392182#L538) being 5 to 7 times faster than the Mustache equivalent.
  80. Upgrading
  81. ---------
  82. See [release-notes.md](https://github.com/wycats/handlebars.js/blob/master/release-notes.md) for upgrade notes.
  83. Known Issues
  84. ------------
  85. See [FAQ.md](https://github.com/wycats/handlebars.js/blob/master/FAQ.md) for known issues and common pitfalls.
  86. Handlebars in the Wild
  87. ----------------------
  88. * [Assemble](http://assemble.io), by [@jonschlinkert](https://github.com/jonschlinkert)
  89. and [@doowb](https://github.com/doowb), is a static site generator that uses Handlebars.js
  90. as its template engine.
  91. * [Cory](https://github.com/leo/cory), by [@leo](https://github.com/leo), is another tiny static site generator
  92. * [CoSchedule](http://coschedule.com) An editorial calendar for WordPress that uses Handlebars.js
  93. * [dashbars](https://github.com/pismute/dashbars) A modern helper library for Handlebars.js.
  94. * [Ember.js](http://www.emberjs.com) makes Handlebars.js the primary way to
  95. structure your views, also with automatic data binding support.
  96. * [Ghost](https://ghost.org/) Just a blogging platform.
  97. * [handlebars_assets](http://github.com/leshill/handlebars_assets): A Rails Asset Pipeline gem
  98. from Les Hill (@leshill).
  99. * [handlebars-helpers](https://github.com/assemble/handlebars-helpers) is an extensive library
  100. with 100+ handlebars helpers.
  101. * [handlebars-layouts](https://github.com/shannonmoeller/handlebars-layouts) is a set of helpers which implement extendible and embeddable layout blocks as seen in other popular templating languages.
  102. * [hbs](http://github.com/donpark/hbs): An Express.js view engine adapter for Handlebars.js,
  103. from Don Park.
  104. * [koa-hbs](https://github.com/jwilm/koa-hbs): [koa](https://github.com/koajs/koa) generator based
  105. renderer for Handlebars.js.
  106. * [jblotus](http://github.com/jblotus) created [http://tryhandlebarsjs.com](http://tryhandlebarsjs.com)
  107. for anyone who would like to try out Handlebars.js in their browser.
  108. * [jQuery plugin](http://71104.github.io/jquery-handlebars/): allows you to use
  109. Handlebars.js with [jQuery](http://jquery.com/).
  110. * [Lumbar](http://walmartlabs.github.io/lumbar) provides easy module-based template management for
  111. handlebars projects.
  112. * [Marionette.Handlebars](https://github.com/hashchange/marionette.handlebars) adds support for Handlebars and Mustache templates to Marionette.
  113. * [sammy.js](http://github.com/quirkey/sammy) by Aaron Quint, a.k.a. quirkey,
  114. supports Handlebars.js as one of its template plugins.
  115. * [SproutCore](http://www.sproutcore.com) uses Handlebars.js as its main
  116. templating engine, extending it with automatic data binding support.
  117. * [YUI](http://yuilibrary.com/yui/docs/handlebars/) implements a port of handlebars
  118. * [Swag](https://github.com/elving/swag) by [@elving](https://github.com/elving) is a growing collection of helpers for handlebars.js. Give your handlebars.js templates some swag son!
  119. * [DOMBars](https://github.com/blakeembrey/dombars) is a DOM-based templating engine built on the Handlebars parser and runtime **DEPRECATED**
  120. * [promised-handlebars](https://github.com/nknapp/promised-handlebars) is a wrapper for Handlebars that allows helpers to return Promises.
  121. * [just-handlebars-helpers](https://github.com/leapfrogtechnology/just-handlebars-helpers) A fully tested lightweight package with common Handlebars helpers.
  122. External Resources
  123. ------------------
  124. * [Gist about Synchronous and asynchronous loading of external handlebars templates](https://gist.github.com/2287070)
  125. Have a project using Handlebars? Send us a [pull request][pull-request]!
  126. License
  127. -------
  128. Handlebars.js is released under the MIT license.
  129. [pull-request]: https://github.com/wycats/handlebars.js/pull/new/master