Tornado 模板(StaticFileHandler/static_path/template_path等) 笔记
使用StaticFileHandler进行首页默认访问页面,最好将StaticFileHandler放在最后面,这样不会覆盖要匹配自定义的路径
import tornado.web
import tornado.ioloop
import tornado.options
import tornado.httpserver
from tornado.options import options
from tornado.web import RequestHandler, StaticFileHandler
import os current_path = os.path.dirname(__file__)
tornado.options.define('port', type=int, default=8000, help="服务器端口") class IndexHandler(RequestHandler):
def get(self):
self.write('OK') if __name__ == '__main__':
tornado.options.parse_command_line()
app = tornado.web.Application([
(r'/(.*)', StaticFileHandler, dict(path=os.path.join(current_path, 'static/html'), default_filename='index.html')),
], debug=True)
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.current().start()
static_path/template_path
static_path:设置静态文件的访问目录
template_path:设置静态页面路径
static_url(): 根据设置的静态,目录寻找静态文件
render():跳转文件,使用render默认的是模板转义。
import tornado.web
import tornado.ioloop
import tornado.options
import tornado.httpserver
from tornado.options import options
from tornado.web import RequestHandler, StaticFileHandler
import os current_path = os.path.dirname(__file__)
tornado.options.define('port', type=int, default=8000, help="服务器端口") class IndexHandler(RequestHandler):
def get(self):
# self.render('index.html') # 跳转静态页面
dict1 = {'name': 'namejr', 'age':22}
self.render('index.html',dict1=dict1) # 使用render()还可以传递参数 if __name__ == '__main__':
tornado.options.parse_command_line()
app = tornado.web.Application([
(r'/', IndexHandler),
# 使用StaticFileHandler进行首页默认访问页面,最好将StaticFileHandler放在最后面,这样不会覆盖要匹配自定义的路径
(r'/(.*)', StaticFileHandler, dict(path=os.path.join(current_path, 'static/html'), default_filename='index.html')),
], debug=True, static_path=os.path.join(current_path, 'static'), template_path=os.path.join(current_path, 'templates'))
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.current().start()
使用render()传递参数接收方法:
<!DOCTYPE html>
<html>
<head>
<title></title>
<!-- static_url使用静态资源文件 -->
<link rel="stylesheet" type="text/css" href="{{ static_url('css/index.css') }}">
</head>
<body>
<h1>namejr</h1>
<p>name :{{ dict1['name'] }}, age:{{ dict1['age'] }}</p>
</body>
</html>
除了上述案例中的将每个debug/static_path/template_path单独添加到tornado.web.Application()中之外,还可以使用**setting
import tornado.web
import tornado.ioloop
import tornado.options
import tornado.httpserver
from tornado.options import options
from tornado.web import RequestHandler
import os tornado.options.define('port', type=int, default=8000, help="服务器端口")
current_path = os.path.dirname(__file__)
setting = dict(debug=True, template_path=os.path.join(current_path, 'templates'), static_path=os.path.join(current_path, 'static')) class IndexHandler(RequestHandler):
def get(self):
self.render('new.html') if __name__ == '__main__':
tornado.options.parse_command_line()
app = tornado.web.Application([
(r'/', IndexHandler),
], **setting)
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.current().start()
关于静态文件使用if..else..等语句
{% if %}...{% elif %}..{% else %}...{% end %}
{% for %} {% end %}
即使用{%%}方式执行python语句,使用{{ num }} 接收静态参数
如何修改render()不进行转义?
下面有这几种方法:
第一种:关闭整个网站的模板转义
在tornado.web.Application()添加参数autoescape=None
app = tornado.web.Application([
(r'/', IndexHandler),
], debug=True, template_path=os.path.join(current_path, 'templates'), autoescape=None)
注:在谷歌浏览器会自动拦截,可在控制台查看拦截原因
第二种:关闭单个页面转义,{% autoescape None %}
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<form method="post">
<textarea name='text'></textarea>
<input type="submit" value="sub">
</form>
{% autoescape None %}
{{ texts }}
</body>
</html>
第三种:单条语句转义,{% raw texts %}
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<form method="post">
<textarea name='text'></textarea>
<input type="submit" value="sub">
</form>
{% raw texts %}
</body>
</html>
第四种:关闭全局转义后想在单个页面进行不转义,{{ escape(texts) }}
关于自定义处理函数
# index.py
import tornado.web
import tornado.ioloop
import tornado.options
import tornado.httpserver
from tornado.options import options
from tornado.web import RequestHandler
import os tornado.options.define('port', type=int, default=8000, help="服务器端口")
current_path = os.path.dirname(__file__) # 构建处理函数
def deal_dict(names):
return ''.join(names) class IndexHandler(RequestHandler):
def get(self):
# 构建数据
dict1 = [
{
'name': ['n', 'a', 'm', 'e', 'j', 'r'],
'age': 21
},
{
'name': ['n', 'a', 'm', 'e', 'm', 'm'],
'age': 22
},
{
'name': ['n', 'a', 'm', 'e', 'm', 'b'],
'age': 23
},
{
'name': ['n', 'a', 'm', 'e', 'a', 'b'],
'age': 24
}
]
self.render('index.html', texts=dict1, func_deal_dict=deal_dict) if __name__ == '__main__':
tornado.options.parse_command_line()
app = tornado.web.Application([
(r'/', IndexHandler),
], debug=True, template_path=os.path.join(current_path, 'templates'))
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.current().start()
index.html:
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<table border="1">
<!-- 进行解析数据 -->
{% for text in texts %}
<tr>
<!-- 使用函数处理 -->
<td>{{ func_deal_dict(text['name']) }}</td>
<td>{{ text['age'] }}</td>
</tr>
{% end %}
</table>
</body>
</html>
父子模板的使用:
# 父模板(index.html)
<!DOCTYPE html>
<html>
<head>
<title>父模板</title>
</head>
<body>
<header>
<p>这是请求头</p>
{% block header %}{% end %}
</header>
<center>
<p>这是请求内容</p>
{% block content %}{% end %}
</center>
</body>
</html>
# 子模板,使用extends继承父模板,用block来填充父模板挖的坑
{% extends 'index.html' %}
{% block header %}
<span>标题</span>
{% end %}
{% block content %}
<span>内容</span>
{% end %}
Tornado 模板(StaticFileHandler/static_path/template_path等) 笔记的更多相关文章
- Tornado模板
--------------------静态文件-------------------- 1.static_path:通过向web.Application类的构造函数传递一个名为static_path ...
- tornado.web.StaticFileHandler
tornado.web.StaticFileHandler 源代码中的解释 class StaticFileHandler(RequestHandler): """A s ...
- Tornado模板配置
#!/usr/bin/env python # -*- coding:utf-8 -*- #tornado模板配置 import tornado.ioloop import tornado.web c ...
- tornado 模板引擎
在tornado的模板引擎中,有两种方式,UImethod与UImodule 自定义方法 在模板中调用方法: tornado:与Django一样使用{{}},但是对于for循环之类,Django以{% ...
- Tornado 模板支持“控制语句”和“表达语句”的表现形式
Tornado 的模板支持“控制语句”和“表达语句”,控制语句是使用 {% 和 %} 包起来的 例如 {% if len(items) > 2 %}.表达语句是使用 {{ 和 }} 包起来的,例 ...
- tornado模板的使用
一. 配置模板路径 settings中使用template_path来指定模板的路径, 实例化服务对象时加载进去即可. 二. 模板的使用 1. 使用self.render()方法可返回指定的html页 ...
- Mvc Model 模板的获取【学习笔记】
MVC的Model模板有两种:一种编辑模式(@Html.EditorFor()).一种显示模式(Html.DisplayFor()). 模板的获取与执行(以下转自这里): 当我们调用HtmlHelpe ...
- tornado模板的自动编码问题(autoescape )
tornado新版(具体版本未知)支持自动转义,比如{{ "<div>" }}不会输出html标签,而是进行转义. {{ module.test(10) }} 也会进行 ...
- javascript模板引擎之artTemplate 学习笔记
<div id="content"></div><div id="content1"></div><h1& ...
随机推荐
- 漫步Java------接口
接口 一.定义 具有相同行为(方法),但是不相关的类 二.特点 只是提供方法,不定义方法的具体实现. 一个类只能继承一个父类,但是接口却可以继承多个接口. 接口是一个引用类型的变量 接口没有构造方法, ...
- Arduino+Avr libc制作Badusb原理及示例讲解
一. 前言 2014年美国黑帽大会上研究人员JakobLell和Karsten Nohl展示了badusb的攻击方法后,国内与badusb相关的文章虽然有了一些,但是大部分人把相关文章都阅读后还是会有 ...
- 更换Homebrew为中科大源
官网:https://brew.sh/index_zh-cn /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com ...
- for循环遍历改用map函数
# for url in urls:# url = response.urljoin(url)# print(url)urls = map(lambda url:response.urljoin(ur ...
- win7英文版
下载个系统,不是一堆木马,就是一堆病毒:相对来说,我还是倾向于相信国外的镜像. https://pcriver.com/operating-systems/windows-7-ultimate-iso ...
- Linux命令学习之路——档案拷贝:cp
使用权限:所有角色 使用方式:cp [ -arf ] source dest / cp [ -arf ] source... Directory 作用:把一个档案拷贝到另一个档案(档案复制),或将多个 ...
- Gym.102059: 2018-2019 XIX Open Cup, Grand Prix of Korea(寒假gym自训第一场)
整体来说,这一场的质量比较高,但是题意也有些难懂. E.Electronic Circuit 题意: 给你N个点,M根线,问它是否是一个合法的电路. 思路: 一个合法的电路,经过一些串联并联关系, ...
- 对Functional Language的认识
What: A functional language is a programming language built over and around logical functions or pro ...
- get新技能:上传了 flv 或 MP4 文件到服务器,可访问总是出现 “无法找到该页”的 404 错误
为什么我上传了 flv 或 MP4 文件到服务器,可访问总是出现 “无法找到该页”的 404 错误 为什么我上传了 flv 或 MP4 文件到服务器,可输入正确地址通过协议来访问总是出现 “无法找到该 ...
- 牛客HJ浇花。
我也不知道这是什么类型的题,算是简单模拟吧.但是有个方法很赞. 开两个数组,一个模拟花,一个记录不同浇花次数花的数量: 要找浇水的次数,那么记每次浇水的开头和结尾就行了,a—b;那么f[a]++;f[ ...