flask之控制语句 if 语句与for语句

简介

控制语句这些内容是写在HTML文件中的,
所有的控制语句都是放在{% … %}中,并且有一个语句{% endxxx %}来进行结束,因为格式比较统一而且字符多,建议将这些加入到自动补全中,参考:https://blog.csdn.net/LCY133/article/details/109098845
Jinja中常用的控制语句有if/for…in…

  • if:if语句和python中的类似,可以使用>,<,<=,>=,==,!=来进行判断,也可以通过and,or,not,()来进行逻辑合并操作
  • for…in…:for循环可以遍历任何一个序列包括列表、字典、元组。并且可以进行反向遍历
    if 语句语法:
{% if  %}
{% else %}
{% endif %}

for语句语法:

{% for  in  %}
{% endfor %}

python代码:

from flask import Flask,render_template

app = Flask(__name__)
# 传参
context = {
    
    
    'username':'lcy1992',
    'age':18,
    'books':['python','java','php'],
    'book2':{
    
    'python':666,
            'java':777,
            'php':888}
}

@app.route('/')
def if_for():
    return render_template('testControl.html',**context)

if __name__ == '__main__':
    app.run(debug=True)

HTML代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<!--    HTML中的控制语句-->
<hr>
    {% if username == 'lcy' %}
        <p>{
   
   { username }}</p>
    {% else %}
        <p>当前用户不是lcy</p>
    {% endif %}
<hr>
    {% for book in books %}
        <p> book is:{
   
   { book }} </p>
    {% endfor %}
<hr>
    {% for bookn,value in book2.items() %}
        <p>{
   
   { bookn }}:{
   
   { value }}</p>
    {% endfor %}
<hr>
    {% for book in books %}
        <p> {
   
   { book }} is:{
   
   { loop.index }} </p>
        <p> {
   
   { book }} is:{
   
   { loop.first }} </p>
        <p> {
   
   { book }} is:{
   
   { loop.last }} </p>
        <p> length is:{
   
   { loop.length }} </p>
<!--        <p> {
    
    { book }} is:{
    
    { loop.index0 }} </p>-->
    {% endfor %}
</body>
</html>

并且Jinja中的for循环还包含以下变量,可以用来获取当前的遍历状态

loop.index 当前迭代的索引(从1开始)
loop.index0 当前迭代的索引(从0开始)
loop.first 是否是第一次迭代,返回True或False
loop.last 是否是最后一次迭代,返回True或False
loop.length 序列的长度

   {% for book in books %}
        <p> {
   
   { book }} is:{
   
   { loop.index }} </p>
        <p> {
   
   { book }} is:{
   
   { loop.first }} </p>
        <p> {
   
   { book }} is:{
   
   { loop.last }} </p>
        <p> length is:{
   
   { loop.length }} </p>
<!--        <p> {
    
    { book }} is:{
    
    { loop.index0 }} </p>-->
    {% endfor %}

猜你喜欢

转载自blog.csdn.net/LCY133/article/details/109112261