Config Functions
Maizzle is fully configured in JavaScript, so you can programmatically set config options or process and make data available to your Templates.
Defining functions
When defining a function, you need to make sure that:
- it returns something
- you invoke it
config.js
const imaginaryLib = require('imaginary-lib')
const foo = function() {
return 'manchu'
}
module.exports = {
foo: foo(), // invoke function defined above
bar: function() {
// do stuff and return
return 'baz'
}(), // invoke function
wha: () => imaginaryLib.render('implicit return 👌')
}
You would access those variables under the page
object:
src/templates/example.html
<x-main>
{{ page.foo }}
{{ page.bar }}
{{ page.wha }}
</x-main>
Result:
build_production/example.html
manchu baz implicit return 👌