Odpowiedzi:
Z dokumentacji projektanta szablonów Jinja2 :
{% if variable is defined %}
value of variable: {{ variable }}
{% else %}
variable is not defined
{% endif %}
{% if variable is not defined %}
do przetestowania odwrotności.
{% if variable is defined and variable %}
sprawdziłby również pustkę
{% if variable is defined %}
ma wartość true, jeśli zmienną jest None
.
Ponieważ not is None
nie jest to dozwolone, oznacza to, że
{% if variable != None %}
to naprawdę twoja jedyna opcja.
variable
jest zawsze oceniane, True
gdy nie jest Brak, {% if variable != None %}
jest równoważne {% if variable %}
.
None
użycie małych liternone
{% if variable is not none %}
Możesz również zdefiniować zmienną w szablonie jinja2 w następujący sposób:
{% if step is not defined %}
{% set step = 1 %}
{% endif %}
A potem możesz użyć tego w następujący sposób:
{% if step == 1 %}
<div class="col-xs-3 bs-wizard-step active">
{% elif step > 1 %}
<div class="col-xs-3 bs-wizard-step complete">
{% else %}
<div class="col-xs-3 bs-wizard-step disabled">
{% endif %}
W przeciwnym razie (jeśli nie użyjesz {% set step = 1 %}
) górny kod wyrzuci:
UndefinedError: 'step' is undefined
Zastanów się nad użyciem domyślnego filtra, jeśli tego potrzebujesz. Na przykład:
{% set host = jabber.host | default(default.host) -%}
lub użyj większej wartości zastępczej z „zakodowaną” jedną na końcu, np .:
{% set connectTimeout = config.stackowerflow.connect.timeout | default(config.stackowerflow.timeout) | default(config.timeout) | default(42) -%}
{% if variable is defined %}
działa, aby sprawdzić, czy coś jest niezdefiniowane.
Możesz uniknąć używania, {% if not var1 %}
jeśli ustawisz domyślne zmienne na False, np
class MainHandler(BaseHandler):
def get(self):
var1 = self.request.get('var1', False)