flask第十七篇——模板【1】
从这一节开始我们就正式进入flask一个重要的模块——模板了。
我们平时看的知乎平台就是Python开发的,可以看到他的很多页面布局都是一样的,比如你现在搜“如何自学Python”,去知乎看他的页面是这样的:
你该搜如何找工作,它的布局仍然是这样:
不用说,知乎的大神们不可能每个页面都做一个.html
的页面吧?!那样累死他们他们也做不过来啊,其实他们用的都是一个模板,也就是说他们只写了一个页面,然后所有的页面都复用这一个页面,那么这个一直可以复用的页面就叫做模板啦~~今天我们要讲的就是这个内容~
可能你眉头一皱——发现事情并不简单aaarticlea/gif;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQImWNgYGBgAAAABQABh6FO1AAAAABJRU5ErkJggg==" alt="" data-src="https://res.wx.qq.com/mpres/htmledition/images/icon/common/emotion_panel/smiley/smiley_13.png" data-ratio="1" data-w="20" />——因为这里要用到HTML的知识了。是的,不过没关系,船长对html也是一窍不通,所以大家跟着我一起写就好了,船长现学现卖,你就不能现看现学吗?废话不多说,开始这一节的内容:
新建一个flask项目,叫templateDemo
,如何新建flask项目之前已经讲过了:
先看一个最基本的代码:
# coding: utf-8
from flask import Flask
app = Flask(__name__) # type: Flask
app.debug = True
@app.route('/')
def hello_world():
return '<h1>这是标题</h1>'
if __name__ == '__main__':
app.run()
执行代码,页面可以看到显示的内容已经是html的页面了:
但是一般来说我们页面内容会很多,我们不可能把HTML内容放在这里乱七八糟的,所以我们可以新建一个HTML文件来存放HTML代码,我们已经知道是模板文件,所以把新建的HTML文件新建在templates文件夹下:
如上图所示,我们新建了一个名为index
的HTML文件在templates文件夹下。
然后按照下图编辑这个HTML文件:
可以看到<h1>这是....</h1>
是在body
标签里面哦。而且h1
标签你写了前面后面是会自动补全的。
现在我们写好了一个简单的HTML文件,回到主代码:
要想调用写好的模板,你需要从flask导入render_template
库,代码如下
# coding: utf-8
from flask import Flask, render_template
app = Flask(__name__) # type: Flask
app.debug = True
@app.route('/')
def hello_world():
return render_template('index.html')
if __name__ == '__main__':
app.run()
保存一下文件Ctrl+s
,然后去浏览器刷新页面(因为我们开启了debug,所以不需要重新运行代码了):
我们看到title
标签就是上面浏览器标签显示的内容,而body
里面的h1
标签显示的字体辣么大~
现在大家就简单的体验了一下模板的作用~
过了十二点了,再讲点吧~
刚才我们把`index.html`文件新建在了`templates`文件夹下,可是有同学不想放在这个文件夹下,那该怎么办呢?我们看一下`Flask`的源码:
可以看到在初始化的时候它规定了模板的文件夹就是templates
,所以现在改一下模板路径就很简单了——初始化的时候多传一个template_folder
参数即可:
上面我们的templates
文件夹下面已经没有文件了,保存代码刷新页面以后可以看到对应的HTML文件的显示。但是如果你去掉app = Flask(__name__, template_folder='static')
的template_folder='static'
,页面就会报找不到模板错误:
如果有同学用Chrome浏览器,刷新的时候可能会提示翻译:
这个时候删掉标签里面的lang="en"
然后重新执行代码,或者你点击那个一律不翻译英语的按钮就可以了。
请关注公众号:自动化测试实战,关注文章最快更新动态
flask第十七篇——模板【1】的更多相关文章
- flask 第四篇 模板语言jinja2
是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...
- flask第二十三篇——模板【5】过滤器
请关注微信公众号:自动化测试实战 过滤器——format格式化 flaskDemo.py # coding: utf-8 from flask import Flask, render_templat ...
- flask第二十篇——模板【3】
请关注公众号:自动化测试实战 现在我们通过查询字符串的方式给render_template传参,我们就要用到flask库的flask.request.args.get()函数先获取参数,在index. ...
- flask第二十七篇——九九乘法表
请关注公众号:自动化测试实战 九九乘法表其实很容易: <table border="1"> <tbody> {% for x in range(1, 10) ...
- Flask最强攻略 - 跟DragonFire学Flask - 第四篇 Flask 中的模板语言 Jinja2 及 render_template 的深度用法
是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...
- Python之路【第十七篇】:Django【进阶篇 】
Python之路[第十七篇]:Django[进阶篇 ] Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...
- Python之路【第十七篇】:Django之【进阶篇】
Python之路[第十七篇]:Django[进阶篇 ] Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...
- Python之路【第十七篇】:Django【进阶篇】
Python之路[第十七篇]:Django[进阶篇 ] Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...
- 解剖SQLSERVER 第十七篇 使用 OrcaMDF Corruptor 故意损坏数据库(译)
解剖SQLSERVER 第十七篇 使用 OrcaMDF Corruptor 故意损坏数据库(译) http://improve.dk/corrupting-databases-purpose-usin ...
随机推荐
- zDialog弹出层插件
效果图如下: 提取自ZCMS的弹出框: 代替window.open.window.alert.window.confirm:提供良好的用户体验: 水晶质感,设计细腻,外观漂亮: 兼容ie6/7/8.f ...
- [Eclipse]保存java文件时,自动删除不需要的包import
1.修改设定:Window->Preferences 2.效果: =>
- 对于"第一次创业者"应该给什么样的建议
转:其实我创业也不是很成功(目前属于第二次).目前为止,基本保证家里足够温饱和足够温馨,偶尔奢侈,但是我坚持走技术路线,不做土豪(因为做不了). 我创业的口号是:成全别人,累死自己!! 有人问 ...
- web常见问题排查
原帖地址:http://mp.weixin.qq.com/s?__biz=MjM5NzUwNDA5MA==&mid=200596752&idx=1&sn=37ecae802f3 ...
- Linux中pid_t类型为int类型
1. 查看man手册,找到pid_t,可以通过getpid函数来看 2. 打开sys/types.h 3. 打开bits/types.h 4. 打开bits/typesizes.h 找不到相关的头文件 ...
- Spoj-COINS-记忆化dp
COINS - Bytelandian gold coins #dynamic-programming In Byteland they have a very strange monetary sy ...
- UVA-10537 The Toll! Revisited (dijkstra)
题目大意:每经过一个地方就要交出相应的货物作为过路费,问将一批货物从起点运到终点,最少需要携带多少货物? 题目分析:在每一站交的过路费由当前拥有的货物量来决定,所以,要以终点为源点,求一次单源最短路即 ...
- Hibernate[延迟加载] [三种状态] [脏检查] [缓存机制]
一.持久化对象的唯一标识 java中按内存地址不同区分同一个类的不同对象,关系数据库用主键区分同一条记录,Hibernate使用OID来建立内存中的对象和数据库中记录的对应关系 什么是OID? 解析: ...
- 【转】c++析构函数(Destructor)
创建对象时系统会自动调用构造函数进行初始化工作,同样,销毁对象时系统也会自动调用一个函数来进行清理工作,例如释放分配的内存.关闭打开的文件等,这个函数就是析构函数. 析构函数(Destructor)也 ...
- mac下csv乱码解决办法
到csv目录下, 用终端执行以下命令: iconv -f UTF8 -t GB18030 a.csv >b.csv