对于一个个人网站,我想使用flask为我的起始页面随机选择一张背景图片(共4张)。尝试创建HTML模板(使用嵌入式CSS进行格式设置)时,生成的HTML不会显示随机选择的图片。
到目前为止,我已经尝试使用url_for(),因为我认为问题可能是jinja无法找到文件,但这不能解决我的问题。
我还查看了空白和定界符,它们在我看来似乎是正确的。
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)
<!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。我哪里出错了? 非常感谢
答案 0 :(得分:0)
random_number
已经在存储所需的路径。在CSS中更改url
:
background: url('{{random_number}}') no-repeat top center;
或者,您可以简单地将intt
传递给模板,并保持原始CSS模板:
return render_template('index.html', random_number=intt)