无法从Flask生成(内联CSS)HTML模板

时间:2019-02-01 18:29:39

标签: python html css flask jinja2

对于一个个人网站,我想使用flask为我的起始页面随机选择一张背景图片(共4张)。尝试创建HTML模板(使用嵌入式CSS进行格式设置)时,生成的HTML不会显示随机选择的图片。

到目前为止,我已经尝试使用url_for(),因为我认为问题可能是jinja无法找到文件,但这不能解决我的问题。

我还查看了空白和定界符,它们在我看来似乎是正确的。

我的app.py中的代码:

flask import Flask, render_template
import random
app = Flask(__name__)

@app.route('/')
def index():
    intt =  random.randint(1, 4)
    random_number = ("../Images/artwork/{}.jpeg".format(intt))
    return render_template('index.html', random_number=random_number)

HTML文件中的代码:

<!DOCTYPE html>
<html>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">


<style>
@font-face {
    font-family: "Pretoria Gross";
    src: url("../Fonts/Pretoria.ttf");
}

ge {
    color:  Yellow;
    font-family: Pretoria Gross;

    font-size:70px;
    text-align: center;
    display:inline-block;
    position:relative;
    width:100%;

    background: url('../Images/artwork/{{random_number}}.jpeg') no-repeat top center;
    background-position: center top;
    background-size:  25% auto;
}
</style>

<a href="about.html">
  <ge>Website<br/>Title<br/>here</ge>
</a>

生成的HTML无法呈现CSS。我哪里出错了? 非常感谢

1 个答案:

答案 0 :(得分:0)

random_number已经在存储所需的路径。在CSS中更改url

background: url('{{random_number}}') no-repeat top center;

或者,您可以简单地将intt传递给模板,并保持原始CSS模板:

return render_template('index.html', random_number=intt)