'Pass variables to Flask's render_template
I want to pass multiple variables from my Flask view to my Jinja template. Right now, I can only pass one. How do I pass multiple variable when rendering a template?
@app.route("/user/<user_id>/post/<post_id>", methods=["GET", "POST"])
def im_research(user_id, post_id):
user = mongo.db.Users.find_one_or_404({'ticker': user_id})
return render_template('post.html', user=user)
Solution 1:[1]
The render_template
function takes any number of keyword arguments. Query for each of the things you need in the template, then pass the results of each query as another argument to render_template
.
@app.route("/user/<user_id>/post/<post_id>")
def im_research(user_id, post_id):
user = get_user_by_id(id)
post = get_user_post_by_id(user, id)
return render_template("post.html", user=user, post=post)
Python also has a built-in locals()
function that will return a dict of all locally defined variables. This is not recommended as it may pass too much and obscures what specifically is being passed.
@app.route("/user/<user_id>/post/<post_id>")
def im_research(user_id, post_id):
user = get_user_by_id(id)
post = get_user_post_by_id(user, id)
return render_template("post.html", **locals())
Solution 2:[2]
return render_template('im.html', user= None, content = xxx, timestamp = xxx)
You can pass as many variables as you need. The api
excerpt:
flask.render_template(template_name_or_list, **context) Renders a template from the template folder with the given context.
Parameters: template_name_or_list – the name of the template to be rendered, or an iterable with template names the first one existing will be rendered context – the variables that should be available in the context of the template.
Solution 3:[3]
It is also possible to pass a list to render_template's context variables, and refer to its elements with Jinja's syntax in HTML.
example.py
mylist = [user, content, timestamp]
return render_template('exemple.html', mylist=l)
exemple.html
...
<body>
{% for e in mylist %}
{{e}}
{% endfor %}
</body>
...
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
Solution | Source |
---|---|
Solution 1 | davidism |
Solution 2 | abhinav |
Solution 3 | Nav |