lijian 48c2e0e9f9 依赖更新为 go mod 1 year ago
..
.gitattributes 48c2e0e9f9 依赖更新为 go mod 1 year ago
.gitignore 48c2e0e9f9 依赖更新为 go mod 1 year ago
.travis.yml 48c2e0e9f9 依赖更新为 go mod 1 year ago
AUTHORS 48c2e0e9f9 依赖更新为 go mod 1 year ago
LICENSE 48c2e0e9f9 依赖更新为 go mod 1 year ago
README.md 48c2e0e9f9 依赖更新为 go mod 1 year ago
context.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
doc.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
error.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
filters.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
filters_builtin.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
helpers.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
lexer.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
nodes.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
nodes_html.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
nodes_wrapper.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
options.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
parser.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
parser_document.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
parser_expression.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
pongo2.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_autoescape.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_block.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_comment.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_cycle.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_extends.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_filter.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_firstof.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_for.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_if.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_ifchanged.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_ifequal.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_ifnotequal.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_import.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_include.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_lorem.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_macro.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_now.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_set.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_spaceless.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_ssi.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_templatetag.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_widthratio.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
tags_with.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
template.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
template_loader.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
template_sets.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
value.go 48c2e0e9f9 依赖更新为 go mod 1 year ago
variable.go 48c2e0e9f9 依赖更新为 go mod 1 year ago

README.md

pongo2

GoDoc Build Status

pongo2 is the django template syntax for Iris.

First impression of a template

<html><head><title>Our admins and users</title></head>
{# This is a short example to give you a quick overview of pongo2's syntax. #}

{% macro user_details(user, is_admin=false) %}
	<div class="user_item">
		<!-- Let's indicate a user's good karma -->
		<h2 {% if (user.karma >= 40) || (user.karma > calc_avg_karma(userlist)+5) %}
			class="karma-good"{% endif %}>
			
			<!-- This will call user.String() automatically if available: -->
			{{ user }}
		</h2>

		<!-- Will print a human-readable time duration like "3 weeks ago" -->
		<p>This user registered {{ user.register_date|naturaltime }}.</p>
		
		<!-- Let's allow the users to write down their biography using markdown;
		     we will only show the first 15 words as a preview -->
		<p>The user's biography:</p>
		<p>{{ user.biography|markdown|truncatewords_html:15 }}
			<a href="/user/{{ user.id }}/">read more</a></p>
		
		{% if is_admin %}<p>This user is an admin!</p>{% endif %}
	</div>
{% endmacro %}

<body>
	<!-- Make use of the macro defined above to avoid repetitive HTML code
	     since we want to use the same code for admins AND members -->
	
	<h1>Our admins</h1>
	{% for admin in adminlist %}
		{{ user_details(admin, true) }}
	{% endfor %}
	
	<h1>Our members</h1>
	{% for user in userlist %}
		{{ user_details(user) }}
	{% endfor %}
</body>
</html>

Documentation

For a documentation on how the templating language works you can head over to the Django documentation. pongo2 aims to be compatible with it.

You can access pongo2's API documentation on godoc.

Caveats

Filters

  • date / time: The date and time filter are taking the Golang specific time- and date-format (not Django's one) currently. Take a look on the format here.
  • stringformat: stringformat does not take Python's string format syntax as a parameter, instead it takes Go's. Essentially {{ 3.14|stringformat:"pi is %.2f" }} is fmt.Sprintf("pi is %.2f", 3.14).
  • escape / force_escape: Unlike Django's behaviour, the escape-filter is applied immediately. Therefore there is no need for a force_escape-filter yet.

Tags

  • for: All the forloop fields (like forloop.counter) are written with a capital letter at the beginning. For example, the counter can be accessed by forloop.Counter and the parentloop by forloop.Parentloop.
  • now: takes Go's time format (see date and time-filter).

Misc

  • not in-operator: You can check whether a map/struct/string contains a key/field/substring by using the in-operator (or the negation of it): {% if key in map %}Key is in map{% else %}Key not in map{% endif %} or {% if !(key in map) %}Key is NOT in map{% else %}Key is in map{% endif %}.

Add-ons, libraries and helpers

Official

  • pongo2-addons - Official additional filters/tags for pongo2 (for example a markdown-filter). They are in their own repository because they're relying on 3rd-party-libraries.

API-usage examples

Please see the documentation for a full list of provided API methods.

Please refer to kataras/iris/_examples/view

Contributors

This project exists thanks to all the people who contribute.