模板简单介绍:

  视图函数:视图函数就是装饰器所装饰的方法,视图函数的主要作用是生成请求的响应,这是最简单的请求。实际上,视图函数有两个作用:处理业务逻辑和返回响应内容。在大型应用中,把业务逻辑和表现内容放在一起,会增加代码的复杂度和维护成本。本节学到的模板,它的作用即是承担视图函数的另一个作用,即返回响应内容。

  模板其实是一个包含响应文本的文件,其中用占位符(变量)表示动态部分,告诉模板引擎其具体的值需要从使用的数据中获取,使用真实值替换变量,再返回最终得到的字符串,这个过程称为“渲染”,Flask是使用 Jinja2 这个模板引擎来渲染模板

  Jinja2(参考概念)

  两个概念:

  Jinja2:是 Python 下一个被广泛应用的模板引擎,是由Python实现的模板语言,他的设计思想来源于 Django 的模板引擎,并扩展了其语法和一系列强大的功能,其是Flask内置的模板语言。

  模板语言:是一种被设计来自动生成文档的简单文本格式,在模板语言中,一般都会把一些变量传给模板,替换模板的特定位置上预先定义好的占位变量名。

  官方文档

  渲染模版函数

  Flask提供的 render_template 函数封装了该模板引擎

  模板简单理解就是把前后的代码分离让开发者高效的开发,让代码结构清晰,耦合度降低

使用render_template:

 网页模板需要flask内的render_template模块:

  

  传参需要先定义好参数传入时render_template()内的第一个参数是html模板名后续加参数,传参时是赋值式  (在html内的标识)= (传入的变量名),也可以用**args,把数据以key value 形式传入字典把整个字典 **变量名传入 到html里直接调用key即可。

  render_template 函数的第一个参数是模板的文件名,后面的参数都是键值对

  {%逻辑运算%}有逻辑运算时必须有{%end%}结束比如:

    {%if sum < 1%}      |          {%for i in sum%}

    {% endif %}            |          {% endfor %}

  html文件内注释可以使用{# 注释内容 #},也可以使用html内的<!-- 注释 -->注释,但是在逻辑运算时如果使用html内的注释会报错,所以建议常用flask内置注释方法 {# 注释内容 #}

PY文件

# -*- encoding: utf-8 -*-
# 网页模板需要导入render_template
from flask import Flask, render_template app = Flask(__name__) app.config.from_pyfile('config.ini') @app.route('/')
def index():
my_str = '你好世界'
my_int = 123
my_list = [1, 2, 3, 48, 93]
my_dict = {'name': '星宇', 'age': 19}
contect = {}
contect['my_shijei'] = my_str
contect['myint'] = 0
contect['mylist'] = [1, 2, 3, 48, 93]
contect['mydict'] = {'name': '牛星宇', 'age': 19}
# 使用render_template模块来渲染模板文件,通过第二个参数传递数据变量
# return render_template('day3.html', my_shijei=my_str, myint=my_int, mydict=my_dict, mylist=my_list)
# 通过**引用来将嵌套dict直接传递给模板
return render_template('day3.html', **contect) if __name__ == "__main__":
app.run()

HTML文件:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
<title>flask网页模板的学习</title>
</head>
<body>
<div>这是我们第一个网页模板</div>
<br />
{# 这是注释,最基本的模板语法输出一个变量 #}
{{ my_shijei + "李毅囧" }}<br />
{# 模板语法可以以下标引用的方式输出list元素#}
{{ mylist[0]}}{{ mylist.1}}<br />
{#模板可以做简单的运算操作#}
{{ myint + 10 }} <br />
{# 模板可以通过调用key取value#}
{{ mydict["name"] }}{{ mydict.age }}
{#使用{%%}来定义简单的逻辑控制代码#}
{% if myint %}
整型存在
{% else %} 不存在
{#使用if判断,一定要有endif用来判断结束逻辑判断#}
{% endif %}
<ul>
{# 使用for循环来遍历list #} {% for itme in mylist %}
<li>{{ itme }}</li>
{% endfor %}
</ul>
{# 使用 if for 嵌套来实现单双行背景色#}
<table style="padding:5px">
{% for item in mylist %}
{#使用loop关键字可以调用循环的索引,用来判断下标单双数#}
{% if loop.index% 2 == 0 %}
<tr style="background-color:tomato">
<td style="border:1px solid black;">{{ item }}</td>
</tr>
{%else%}
<tr style="background-color:violet">
<td style="border:1px solid black;">{{ item }}</td>
</tr>
{% endif%} {% endfor %}
</table>
</body>
</html>

render_template 网页模板的更多相关文章

  1. Flask网页模板的入门

    #网页模板需要导入render_template from flask import Flask,render_template   方法一: #使用render_template模块来渲染模板文件 ...

  2. 15款免费的 HTML5/CSS3 响应式网页模板

    如果你想快速制作出一个优秀的网站,网站模板一定是必不可少的.网页设计师和开发人员也可以从网站模板入手,学习先进的布局方式和编码风格.下面这个列表为大家挑选了15款免费的 HTML5/CSS3 响应式网 ...

  3. 20款响应式的 HTML5 网页模板【免费下载】

    下面的列表集合了20款响应式的 HTML5 网页模板,这些专业的模板能够让你的网站吸引很多的访客.除了好看的外观,HTML5 模板吸引大家的另一个原因是由于其响应性和流动性.赶紧来看看. 您可能感兴趣 ...

  4. 30余套系统模版|DIV+CSS网页模板|简洁大气系统模板

    30余套系统模版|DIV+CSS网页模板|简洁大气系统模板.都是一些后台系统的模版,很适合开发一些管理系统,办公系统,网站后台系统等.使用很广泛,很实用的系统模版. 下载地址: 点击下载

  5. .net邮件发送实例 邮件内容为网页模板

    .net邮件发送实例 邮件内容为网页模板 2009-07-03 09:31:01|  分类: .NET|字号 订阅      Encoding encoding = Encoding.GetEncod ...

  6. (转)dedecms网页模板编写

    网页模板就是templets中的htm文件,所以编写模板就是要编写html.这篇文章不是关于标签的具体使用,而是对网页模板的一些理解.包括基本的标签语法,封面模板,列表模板和文档模板的关系. 一 关于 ...

  7. Play学习 - 体验网页模板

    在经过无数个尝试后,最终用sbt把play所依赖的所有包都下载下来了,现在可以非常快速编译运行了.今天体验了下网页模板,觉得非常不错,在这里做个简单的介绍. 原文说明: A Play Scala te ...

  8. Django加载静态网页模板

    Django加载静态网页模板 步骤: 第一步:在子系统blog根目录下新建模版目录templates,里面新建一个login.html <!DOCTYPE html> <html l ...

  9. 快速完成网页设计,10个顶尖响应式HTML5网页模板助你一臂之力

    为了寻找一个优质的网页模板,网页设计师和开发者往往可能会花上大半天的时间.不过幸运的是,现在的网页设计师和开发人员已经开始共享HTML5,Bootstrap和CSS3中的免费网页模板资源.鉴于网站模板 ...

随机推荐

  1. WPF设置软件界面背景为MediaElement并播放视频

    在我们的常见的软件界面设计中我们经常会设置软件的背景为SolidColorBrush或者LinerColorBrush.RadialGradientBrush 等一系列的颜色画刷为背景,有时我们也会使 ...

  2. windows 10 & 禁用服务.bat

    windows 10 & 禁用服务.bat 禁用服务.bat @echo off net stop WSearch net stop wuauserv net start TrustedIns ...

  3. SELECT IDENT_CURRENT(tableName)和自增长列的纠结

    项目中要用到一个功能:主表主键为自增长,要求在插入主表数据前先获得主表要插入数据的主键ID值,用在插入子表时获取主键ID.在网上搜了一下,发现SELECT IDENT_CURRENT(TableNam ...

  4. C-Lodop提示“有窗口已打开,先关闭它(持续如此请刷新页面)!”

    c-lodop显示“有窗口已打开,先关闭它(持续如此时请刷新页面)!”如果连续执行多个预览语句等导致的,可以预先判断一下,并可以自定义修改窗口已打开的提示,该默认提示的位置如本博客的下图http:// ...

  5. static类型的变量

    c语言中变量的储存类型有以下四种 auto  如果没有定义储存类型  默认就是这个类型  比如  int a = 10;  储存类型就是 auto:编译器会跟你定义的位置,以及用途,自动帮你决定使用那 ...

  6. vue 使用技巧总结 19.01

    组件中箭头函数的使用 不要使用箭头来定义任意生命周期钩子函数: 不要使用箭头来定义一个 methods 函数: 不要使用箭头来定义 computed 里的函数: 不要使用箭头定义 watch 里的函数 ...

  7. ASP.NET Core Building chat room using WebSocket

    Creating “Login form” We use here simple form where user can insert his or her preferred nick name f ...

  8. 本科理工男如何学习Linux

    我是一个本科学电子的理工男,但是一直对计算机感兴趣,所以平时自己在课下喜欢学一些与计算机有关的东西.由于对计算机感兴趣,所以后来我参加了学校的计算机社团,在那里接受一些培训和指导.当时在社团里看到师兄 ...

  9. 【C/C++】查找(一):静态查找表

    {静态查找表 + 动态查找表} 所谓动态,就是,找的时候没有则添加,或者能删除 关键字:primary key:用来表示查找表中的一条记录 {主关键字 + 次关键字} 主关键字是唯一的,用来唯一的标识 ...

  10. HTML5获取地理位置信息

    <!DOCTYPE html> <html> <head> <title>Location</title> <meta charset ...