tornado框架基础04-模板基础

01 模板

模板演示

配置路径

在 application 中配置模板文件和静态文件的路径:

template_path='templates', static_path='static',

模板

<body> 欢迎{{ username }}登录 </body>

Handler

class TemplatesHandler(tornado.web.RequestHandler):

def get(self):

  self.write('templates')

  self.render('01in_out.html')

def post(self, *args, **kwargs):

user = self.get_argument('name', 'no')

self.render('02templates.html',

username=user

) #将参数传入模板文件.

在tornado中,模板就是一个html文件,但是模板通过模板语法,由tornado服务渲染之后,可以动态的往页面中填入数据

tornado自带模板语法,不需要再用其他的模板插件

模板概念

必须掌握:模板就是html文件,只是其中加入了模板语法,需要服务器的渲染,才能正常显示数据

02 模板符号

{{expression}}

用 {{ expression }} 中间是任何 python 表达式,或者是一个变量

示例:{{ 1 + 1 }}

{{ time.time() }} #在handler页面中要import time,并且要在handler中传入time参数.

{%  directives %}

其他的模板指令

示例

{% if 1 %}     this is if {% end %}

{#  … #}

在模板中要注释python表达式的运行,需要使用这个模板语法

示例

{# time.time() #}}

{{!   {%!   {#!

取消执行,如果不想执行内容,需要在页面上打印出模板符号,只需要加上感叹号( ! )即可

示例

{{! 1 + 1}}

{%! if 1 %} this is if {%! end %}

{#! time.time() #}}

在模板里定义一个变量要用set

{% set a = 0 %}

对变量的改变也要用set

{% set a += 1 %}

控制语句

if判断

在模板中可以使用 if 判断

注意:最后需要以 {% end %} 结尾

示例

{% if username != 'no' %}

欢迎{{ username }}登录 {% else %}

请登录

{% end %}

循环语句

for 循环

在 tornado 模板中可以使用 for 循环

注意:最后需要以 {% end %} 结尾

示例

{% for i in urllist %}

{{ i }}

{% end %}

while 循环

在 tornado 模板中可以使用 while 循环

注意:最后需要以 {% end %} 结尾

示例

{% set a = 0 %}

{% while a<5 %}

{{ a }}     {% set a += 1 %}

{% end %}

模板语法

{{

此符号中放入任意 python 表达式,或者模板中的变量

{%

此符号中放入模板中的命令,比如 if 、for 和 while 等

需要注意的是,使用 if 等命令是,需要加上 {% end %}

除此之外,异常处理 try 也可以在模板中使用,但是这样做会让模板变得像 python 模块一样,因此并不建议大家这么做

{#

模板中的注释语句,可以让模板中指令不执行

03 模板转义

参数

atga = "百度" #里面是百度的网址,这里显示的”百度“

模板

{{ atga }}

转义

页面并没有解析,只是当作一个字符串,直接在页面上打印出来

tornado默认是自动的转义,传入的数据都会当作字符串,不会被浏览器解析

模板去掉转义

局部去掉转义

{% raw atga %}

raw

raw 可以自模板中去掉转义,让 tornado 在渲染的时候不去转义变量

模板去掉转义

模板去转义/全局取消转义,相当于全部加raw

{% autoescape None %}

autoescape

在模板中添加上面代码之后,当前模板不再转义

escape

{{ escape(atga) }}

在开启模板不转义之后,可以使用 escape 来添加转义

全局去掉转义

在 Application 中添加如下配置:

autoescape=None,

autoescape

去掉整个项目的转义,配置之后,整个项目中的模板不再转义

<!-- -->前端注释的内容不显示但是还是会执行的.

04 静态文件引用

Application

static_path='static',

两种引入方式

tornado框架基础04-模板基础

路由配置

添加此配置之后,tornado就能自己找到静态文件

static/

自动查找

在 Tornado 模板中,static 是个关键词,能够自动替换成 static_path 后的内容

static_url

添加版本号

使用此方法时,Tornado 会自动地给静态文件添加版本号,第2次请求的时候,如果版本号更改了,浏览器会自动的缓存新的静态文件,

html里面的注释写法:

<!-- abc -->在浏览器不显示但是执行.

上一篇:tornado框架基础09-cookie和session


下一篇:原生JS实现点击一个按钮显示一个div,再点击按钮div隐藏,或点击除div外其它空白处div隐藏