Core Topics
Advanced Topics
Misc
Tools
HTML-to-Mithril Template Converter
If you already have your HTML written and want to convert it into a Mithril template, you can use the tool below for one-off manual conversion.
Automatic HTML-to-Mithril Template Converter
There's a tool called MSX by Jonathan Buchanan that allows you to write templates using HTML syntax, and then automatically compile them to Javascript when files change.
It is useful for teams where styling and functionality are done by different people, and for those who prefer to maintain templates in HTML syntax.
The tool allows you to write code like this:
todo.view = function() {
return <html>
<body>
<input onchange={m.withAttr("value", app.vm.description)} value={app.vm.description()}/>
<button onclick={app.vm.add}>Add</button>
</body>
</html>
};
Note, however, that since the code above is not valid Javascript, this syntax can only be used with a preprocessor build tool such as the provided Gulp.js script.
This tool is also available as a Rails gem, created by Jordan Humphreys.
Mithril Template Compiler
You can pre-compile Mithril templates to make them run faster. For more information see this page:
Typescript Support
There's a type definition file that you can use to add Mithril support to Typescript
You can use it by adding a reference to your Typescript files. This will allow the compiler to type-check calls to the Mithril API.
/// <reference path="mithril.d.ts" />
Internet Explorer Compatibility
Mithril relies on some Ecmascript 5 features, namely: Array::indexOf
, Array::map
and Object::keys
, as well as the JSON
object.
The easiest way to polyfill these features is to include this script:
<script src="https://cdnjs.cloudflare.com/ajax/libs/es5-shim/4.0.3/es5-shim.min.js"></script>
This will provide all the polyfills required for the browser. You can alternatively include only specific polyfills:
<script src="https://polyfill.io/readable/gimme(array.prototype.indexof,object.keys,function.prototype.bind,array.prototype.foreach,JSON)"></script>
You can also use other polyfills to support these features in IE7.
ES5 Shim or Mozilla.org's Array::indexOf, Array::map and Object::keys
Mithril also has a dependency on XMLHttpRequest. If you wish to support IE6, you'll need a shim for it. IE7 and lower do not support cross-domain AJAX requests.
In addition, note that most m.route
modes rely on history.pushState
in order to allow moving from one page to another without a browser refresh. IE9 and lower do not support this feature and will gracefully degrade to page refreshes instead.