当前位置:网站首页>[flask] static file and template rendering
[flask] static file and template rendering
2022-07-06 01:27:00 【Coriander Chrysanthemum】
Preface article :
Flask Departure and implementation are based on Flask The smallest application
Static files Static Files
Static files are mainly web Some pictures will be used in the application ,css file ,js Files, etc. to achieve an elegant web page . This is also an indispensable part of dynamic websites . that Flask Will solve it for you .
use Flask document : Just create a folder called static in your package or next to your module and it will be available at /static
on the application. in other words , Create in the project path static Folder , Or create at the same level of the module /static
Folder is ok ,flask You will find the contents of static files in these paths .
Static files also have a path in the system , Suppose there is a static/style.css
The file of . Then you can use the following methods to locate :
url_for('static', filename='style.css')
Template rendering Rendering Templates
If you use Python To build a through string splicing and so on HTML page , I'm afraid it will kill people . besides , You also have to consider injecting attacks, etc . With this demand , There is a concept of template engine , Popular said : This gadget can put html Code and flask Apply the returned data for dynamic integration , And then render it as html The code is displayed on the browser . If you know Java in JSP、Thymeleaf I should have understood .Flask The default template rendering engine is Jinja2.
Render a template ( One html) It uses render_template()
Method . What we need to do is to provide the name of the template and the variables to be passed to the template engine as keyword parameters . Here is a simple example of how to render a template :
from flask import render_template
@app.route('/hello/')
@app.route('/hello/<name>')
def hello(name=None):
return render_template('hello.html', name=name)
Flask Will be from templates
Find the corresponding file in the folder , This templates
Storage address and static
similar . You can refer to the following understanding :
- modular
/application.py /templates /hello.html
- package
/application
/__init__.py
/templates
/hello.html
Then for the template , We can use Jinja2 All functions of the template . This also has to know Jinja2 The document of :Jinja2.
The following is a template use case :
<!doctype html>
<title>Hello from Flask</title>
{
% if name %}
<h1>Hello {
{
name }}!</h1>
{
% else %}
<h1>Hello, World!</h1>
{
% endif %}
In the template , We can also visit config、request、session and g These objects and url_for()
and get_flashed_messages()
function . What are these? I will continue to introduce them later , In short, it can be used directly in the template .
Some pages have public sections , As header 、 Navigation and footer , If you can put the public part into a template , Other templates can be simply reused . This is the inheritance of the template (inheritance). This needs to be understood in depth , You can refer to the official .
Auto escape enabled , So if name
contain HTML, It will escape automatically . If we can trust a variable and know that it is safe HTML( for example , Because it comes from will wiki The tag is converted to HTML Module ), We can use Markup
Class or use | safe
The filter marks it as a security template .
Markup
A brief introduction to the use of class :
from markupsafe import MarkUp
print(Markup('<strong>Hello %s!</strong>') % '<blink>hacker</blink>')
# Markup('<strong>Hello <blink>hacker</blink>!</strong>')
print(Markup.escape('<blink>hacker</blink>'))
# Markup('<blink>hacker</blink>')
print(Markup('<em>Marked up</em> » HTML').striptags())
# Marked up » HTML
summary
Okay , I know so much today . Go and see the paper .
边栏推荐
- Leetcode 208. 实现 Trie (前缀树)
- SPIR-V初窺
- 【已解决】如何生成漂亮的静态文档说明页
- 一图看懂!为什么学校教了你Coding但还是不会的原因...
- Cglib dynamic agent -- example / principle
- Code Review关注点
- 【SSRF-01】服务器端请求伪造漏洞原理及利用实例
- servlet(1)
- 3D vision - 4 Getting started with gesture recognition - using mediapipe includes single frame and real time video
- 3D model format summary
猜你喜欢
037 PHP login, registration, message, personal Center Design
【Flask】官方教程(Tutorial)-part3:blog蓝图、项目可安装化
leetcode刷题_平方数之和
XSS learning XSS lab problem solution
c#网页打开winform exe
【SSRF-01】服务器端请求伪造漏洞原理及利用实例
Huawei converged VLAN principle and configuration
MATLB|实时机会约束决策及其在电力系统中的应用
[技术发展-28]:信息通信网大全、新的技术形态、信息通信行业高质量发展概览
Folio.ink 免费、快速、易用的图片分享工具
随机推荐
Introduction to robotics I. spatial transformation (1) posture, transformation
Condition and AQS principle
什么是弱引用?es6中有哪些弱引用数据类型?js中的弱引用是什么?
UE4 unreal engine, editor basic application, usage skills (IV)
A glimpse of spir-v
SSH login is stuck and disconnected
Huawei Hrbrid interface and VLAN division based on IP
Une image! Pourquoi l'école t'a - t - elle appris à coder, mais pourquoi pas...
【Flask】静态文件与模板渲染
Leetcode1961. Check whether the string is an array prefix
SCM Chinese data distribution
How to get all sequences in Oracle database- How can I get all sequences in an Oracle database?
c#网页打开winform exe
servlet(1)
LeetCode 322. Change exchange (dynamic planning)
FFT learning notes (I think it is detailed)
Leetcode sword finger offer 59 - ii Maximum value of queue
干货!通过软硬件协同设计加速稀疏神经网络
Netease smart enterprises enter the market against the trend, and there is a new possibility for game industrialization
3D model format summary