经过了第一章的内容,已经可以做出一些简单的页面,首先用这种方式做一个登录页面,首先要创建一个login的路由方法:

@app.route("/login",methods=["GET"])
def login():
html="<form method='post'>" \
"<table>" \
"<tr><td>请输入用户名</td><td><input type='text' name='username'/></td></tr>" \
"<tr><td>请输入密码</td><td><input type='password' name='password'/></td></tr>" \
"<tr><td><input type='submit' value='登录'/></td></tr>" \
"</table>" \
"</post>"
return html
这个页面返回后是一个简单的登录页,显示结果如下:
然后是一个登录的post返回页:
@app.route("/login",methods=["POST"])
def loginPost():
username=request.form.get("username","")
password=request.form.get("password","")
if username=="test" and password=="123" :
return "登录成功"
else:
return "登录失败"
输入test和123后,显示登录成功
功能上当然是实现了,但是从其他方面来说,却很难说它是一个能够实际应用的程序,即使不考虑js脚本和css样式表,就从简简单单的维护来说,就是一场噩梦,比如说像增加一个验证码框,我想不会有人认为这是一件愉快的工作。
所以,首先来说,我们要把页面html部分立出来,这点,flask提供了jinja2模板引擎来实现。
jinja2模板引擎同样符合flask最基础的约定,即众多配置中都有一个基础的默认值,相对jinja2来说,有一个最重要的默认值,即模板文件放在templates文件夹,这个文件夹虽然可以自定义,但目前来说,使用默认值已经足够了。
好,首先在PyCharm的项目根目录创建templates文件夹,然后在文件夹内创建login.html文件,当然目录结构如下:
在login.html中输入代码如下:
<!DOCTYPE html> <html> <head> <title>欢迎您登陆--牛博客</title> </head> <body> <form method='post'> <table> <tr><td>请输入用户名</td><td><input type='text' name='username'/></td></tr> <tr><td>请输入密码</td><td><input type='password' name='password'/></td></tr> <tr><td><input type='submit' value='登录'/></td></tr> </table> </form> </body> </html>
代码很简单,也名没有进行样式方面的美化,其实目前就我来说,仅仅是因为有了智能感知,就有足够的理由使用模板了,然后,对default.py的login方法进行修改代码为:
from flask import render_template #头部,引入模板渲染方法
@app.route("/login",methods=["GET"])
def login():
return render_template("/login.html")
#渲染模板,默认找templates文件夹下的login.html文件
由于html模板内的代码和直接直接写在py文件中的一样,所以此时刷新页面,显示效果和刚刚相同,虽然显示效果没有明显的改观,但此时如果修改html中的某一元素,则会方便很多。
关于jinja2模板引擎还支持一些更强大的功能,比如使用index做一些说明:
基本用法
修改default.py中的部分代码为:
from flask import render_template #页头,导入渲染函数
@app.route("/")
def index():
return render_template("index.html",site_name='myblog')
index.html中的代码为:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>{{site_name}}</title>
</head>
<body>
<h1>这个站点的名字为 {{site_name}} </h1>
</body>
</html>
flask的render_template函数支持多参数,其中函数的第一个参数为模板名,之后可以提供若干参数,均为键值对,为模板中的变量提供数据。如此例子中,为site_name提供了myblog的值,而模板内使用{{参数名}}来表示一个变量
此时浏览器输入地址输出结果为:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>myblog</title> </head> <body> <h1>这个站点的名字为 myblog </h1> </body> </html>
jinja2模板还提供了一些变量过滤器,如代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>{{site_name|upper}}</title>
</head>
<body>
<h1>这个站点的名字为 {{site_name}} </h1>
</body>
</html>
这时输出为:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>MYBLOG</title> </head> <body> <h1>这个站点的名字为 myblog </h1> </body> </html>
常用过滤器如下
safe 不转义
capitalize 首字母大写
lower 转换为小写
upper 转换为大写
trim 去收尾空格
striptages 去除html标签
除此之外,Jinja2的变量还可以是一些复杂类型,甚至可以使用一些复杂类型的常用方法,如:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>{{site_name[2:]}}</title>
</head>
<body>
<h1>这个站点的名字为 {{site_name}} </h1>
</body>
</html>
这时输出为:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>blog</title> </head> <body> <h1>这个站点的名字为 myblog </h1> </body> </html>
控制语句
控制语句是一个模板的基本功能,同样的jinja2也提供了相应的功能:
//选择
{% if name=='test' %}
这是测试
{% else %}
{{name}},你好
{% endif %}
//循环
<ul>
{% for blog in blogs%}
{{ blog.title }}
{% endfor%}
</ul>
除了这些基本用法,模板还为一些代码的重复使用提供了宏的功能,如将如下代码写入macros.html文件中
{% macro render_title(blog)%}
<li>{{blog.title}}</li>
{% endmacro%}
然后在之前的模板中:
{% import 'macros.html' as macros %}
<ul>
{% for blog in blogs %}
{{ macros.render_title(blog) }}
{% endfor %}
</ul>
执行结果与之前的完全相同
Jinja2还提供了一个更为强大的功能,即模板继承,这个个人感觉有点像java的sitemesh框架,它首先需要创建一个base.html的基模板:
<!DOCTYPE html>
<html>
<head>
{% block head %}
<meta charset="UTF-8">
<title>{% block title%} {% endblock %} - 牛博客</title>
<script src="http://cdn.bootcss.com/jquery/2.2.4/jquery.min.js"></script>
{% endblock %}
</head>
<body>
{% block body %}
{% endblock %}
</body>
</html>
其中block标签的意思表示在子模板中可以修改,具体到此例子,则可修改的部分为 head,title,body。下面为子模板代码:
{% extends "base.html" %}
{% block title %}{{site_name[2:]}}{% endblock %}
{% block head %}
{{super()}}
{% endblock %}
{% block body %}
<h1>这个站点的名字为 {{site_name}} </h1>
{% endblock %}
此时执行结果仍为:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>blog</title> </head> <body> <h1>这个站点的名字为 myblog </h1> </body> </html>
现在有了模板引擎,不管怎么说,仅仅就页面层来说,已经可以很轻松的做出一些不错的功能了,但很明显,现在的界面还不是很美观,下一章将把现在主流的前端框架bootstrap与flask框架进行整合。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# flask
# jinja2
# 模板引擎
# wtf
# 是一个
# 请输入
# 这是
# 默认值
# 转换为
# 创建一个
# 显示效果
# 有一个
# 我想
# 放在
# 还可以
# 第一个
# 就有
# 欢迎您
# 最重要
# 均为
# 不是很
# 是从
# 它是
# 要把
相关文章:
如何快速搭建虚拟主机网站?新手必看指南
建站之星2.7模板:企业网站建设与h5定制设计专题
制作国外网站的软件,国外有哪些比较优质的网站推荐?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何用花生壳三步快速搭建专属网站?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
如何挑选高效建站主机与优质域名?
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何在IIS中新建站点并配置端口与IP地址?
用v-html解决Vue.js渲染中html标签不被解析的问题
建站之星如何开启自定义404页面避免用户流失?
已有域名和空间如何搭建网站?
网站制作的步骤包括,正确网址格式怎么写?
建站之星导航配置指南:自助建站与SEO优化全解析
建站之星北京办公室:智能建站系统与小程序生成方案解析
岳西云建站教程与模板下载_一站式快速建站系统操作指南
如何在Windows服务器上快速搭建网站?
如何通过西部建站助手安装IIS服务器?
广平建站公司哪家专业可靠?如何选择?
建站之星logo尺寸如何设置最合适?
建站主机默认首页配置指南:核心功能与访问路径优化
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
建站之星如何通过成品分离优化网站效率?
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
香港服务器如何优化才能显著提升网站加载速度?
如何注册花生壳免费域名并搭建个人网站?
seo网站制作优化,网站SEO优化步骤有哪些?
制作农业网站的软件,比较好的农业网站推荐一下?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
如何通过WDCP绑定主域名及创建子域名站点?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
大连网站制作公司哪家好一点,大连买房网站哪个好?
开封网站制作公司,网络用语开封是什么意思?
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
已有域名如何快速搭建专属网站?
内网网站制作软件,内网的网站如何发布到外网?
Android自定义控件实现温度旋转按钮效果
网站制作报价单模板图片,小松挖机官方网站报价?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
python的本地网站制作,如何创建本地站点?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
黑客入侵网站服务器的常见手法有哪些?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
如何在宝塔面板创建新站点?
建站VPS能否同时实现高效与安全翻墙?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
*请认真填写需求信息,我们会在24小时内与您取得联系。