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就能自己找到静态文件

static/

自动查找

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

static_url

添加版本号

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

html里面的注释写法:

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

tornado框架基础04-模板基础的更多相关文章

  1. Tornado框架中视图模板Template的使用

    上文的程序中有这样一段: class MessageHandler(tornado.web.RequestHandler): def get(self): self.write(''' <htm ...

  2. SQL从入门到基础 - 04 SQLServer基础2(数据删除、数据检索、数据汇总、数据排序、通配符过滤、空值处理、多值匹配)

    一.数据删除 1. 删除表中全部数据:Delete from T_Person. 2. Delete 只是删除数据,表还在,和Drop Table(数据和表全部删除)不同. 3. Delete 也可以 ...

  3. tornado框架基础10-websocket

    websocket 01 长轮询 在网页,我们经常扫码登录,结合之前的学习的知识点,来思考下,前端是如何知道用户在手机上扫码登录了呢? 长轮询:客户端不断的向服务器发送请求 缺点: \1. 开销大 \ ...

  4. tornado框架基础05-模板继承、UImodul和UImethods

    01 模板继承 父模板​ <html lang="en"> <head>     <meta charset="UTF-8"> ...

  5. Python开发【第二十一篇】:Web框架之Django【基础】

    Python开发[第二十一篇]:Web框架之Django[基础]   猛击这里:http://www.cnblogs.com/wupeiqi/articles/5237704.html Python之 ...

  6. tornado框架&三层架构&MVC&MTV&模板语言&cookie&session

    web框架的本质其实就是socket服务端再加上业务逻辑处理, 比如像是Tornado这样的框架. 有一些框架则只包含业务逻辑处理, 例如Django, bottle, flask这些框架, 它们的使 ...

  7. Vue基础项目模板

    https://github.com/wanglong/vue-element-admin.git 优化 Vue CLI 3 构建的前端项目模板(1)- 基础项目模板介绍 一站式开源运维平台,分享给大 ...

  8. Django框架04 /模板相关、别名/反向解析/路由分发

    Django框架04 /模板相关.别名/反向解析/路由分发 目录 Django框架04 /模板相关.别名/反向解析/路由分发 1. 语法 2. 变量/万能的点 3 . 过滤器 4. 标签Tags 5. ...

  9. javaSE基础04

    javaSE基础04 一.三木运算符 <表达式1> ? <表达式2> : <表达式3> "?"运算符的含义是: 先求表达式1的值, 如果为真, ...

  10. javascript基础04

    javascript基础04 1.循环语句 1.While 语句: while (exp) { //statements; } var i = 1; while(i < 3){ alert(i) ...

随机推荐

  1. expect实现配置机器信任关系

    利用expect的交互功能,自动配置信任机器之间的信任关系. 代码里会判断机器是否生成了秘钥,如果没有生成过,则自动帮助你执行 ssh-keygen #!/bin/sh expect_ssh_copy ...

  2. Docker镜像文件操作

    1什么是Docker镜像 Docker镜像是由文件系统叠加而成(是一种文件的存储形式).最底端是一个文件引导系统,即bootfs,这很像典型的Linux/Unix的引导文件系统.Docker用户几乎永 ...

  3. WOW.js 动画使用

    有的页面在向下滚动的时候,有些元素会产生细小的动画效果.虽然动画比较小,但却能吸引你的注意.比如刚刚发布的 iPhone 6 的页面(查看).如果你希望你的页面也更加有趣,那么你可以试试 WOW.js ...

  4. 使用Ctex中遇到的一些问题

    一般下载好Ctex,我是使用Latex+dvi2pdf完成编译的,但是发现推荐的使用为:1)运行CCT & Latex命令生成两次dvi和ps文件 2)使用dvi2pdf编译dvi文件生成pd ...

  5. Educational Codeforces Round 19 C

    Description Petya recieved a gift of a string s with length up to 105 characters for his birthday. H ...

  6. Backbone学习记录(5)

    数据与服务器 var User=Backbone.Model.extend({ defaults:{ name:'susan', age:18 }, url:'/user'//数据提交的路径 }); ...

  7. AJPFX的内存管理小结

    管理范围:任何继承于 NSObject的对象原理:每一个对象都有引用计数器当使用alloc new 和 copy创建对象时引用计数器被设置为1给对象发送一条retain消息 ,引用计数器加1     ...

  8. 【学习笔记】深入理解js原型和闭包(6)——继承

    为何用“继承”为标题,而不用“原型链”? 原型链如果解释清楚了很容易理解,不会与常用的java/C#产生混淆.而“继承”确实常用面向对象语言中最基本的概念,但是java中的继承与javascript中 ...

  9. 【js】js导出表格到excel

    js: function method(tableid) //读取表格中每个单元到EXCEL中 { var curTbl = document.getElementById(tableid); var ...

  10. 【HEVC简介】DB-DeBlock Filter

    参考论文:HEVC Deblocking Filter <HEVC标准介绍.HEVC帧间预测论文笔记>系列博客,目录见:http://www.cnblogs.com/DwyaneTalk/ ...