2015-12-19 14:52:17 +01:00
|
|
|
title: jinja_env
|
|
|
|
---
|
|
|
|
type: property
|
|
|
|
---
|
|
|
|
summary: The configured Jinja 2 Environment.
|
|
|
|
---
|
|
|
|
body:
|
|
|
|
|
|
|
|
This object is a configured Jinja2 environment. For more information you can
|
2022-02-27 21:25:29 +01:00
|
|
|
refer to the [Jinja 2 Documentation :ext](https://jinja.palletsprojects.com/en/3.0.x/api/#jinja2.Environment).
|
2015-12-19 14:52:17 +01:00
|
|
|
|
|
|
|
This is where plugins can inject additional data like custom filters, tests
|
|
|
|
or global functions.
|
|
|
|
|
|
|
|
## Plugin Example
|
|
|
|
|
|
|
|
```python
|
|
|
|
from lektor.pluginsystem import Plugin
|
|
|
|
|
|
|
|
class MyPlugin(Plugin):
|
|
|
|
...
|
|
|
|
|
|
|
|
def on_setup_env(self, **extra):
|
|
|
|
def shout_filter(value):
|
|
|
|
return unicode(value).upper() + '!!!!1111'
|
|
|
|
self.env.jinja_env.filters['shout'] = shout_filter
|
|
|
|
```
|
|
|
|
|
|
|
|
Then you can use this filter from templates:
|
|
|
|
|
|
|
|
```html+jinja
|
|
|
|
<h1>{{ page.title|shout }}</h1>
|
|
|
|
```
|